Bootstrap Carousel Tutorial: getting started, then customizing — example code & bugs

Recently I had “great fun” modifying bootstrap v3’s image gallery slideshow thingy, Carousel (click here to see an interactive example).

It has some nice features built-in, like indicators for what slide you are on, auto-scaling so it works on any browser window size, and an easy way to select options like cycling the carousel continuously, changing the interval between auto-slides, or reacting to keyboard events.

I made some modifications to get it to look and behave the way I wanted. Namely, I wanted readable captions underneath the images. Bootstrap has the captions overlaid on the image by default, and white-on-white doesn’t work so well.

I mostly succeeded… here’s a screenshot:

Screenshot from 2015-01-21 15:36:57
Live at doc.arvados.org someday soon…

…although I still dislike how verbose the Carousel code is. Oh well, our docs site was already using Bootstrap.

The how-to on bootstrap’s page is pretty terse and kind of confusing for me, so I’m writing up a more detailed explanation here.

stuff needed

From http://getbootstrap.com/getting-started/, download the zip file. You’ll need

1. css/bootstrap.css (you can use the .min version if you’d like, which is just compressed into non-human-readable form)

2. js/bootstrap.js (you can also get away with just carousel.js).

You’ll also need jquery.js from http://jquery.com/download/, try the link “Download the compressed, production jQuery 1.11.2”.

Note: We’ll include the javascript files at the end of HTML so most of the page loads quicker.

how to

Alright, now how do you include all these files? (see this gist for the full HTML file, or download a self-contained zip file of all the files: bootstrap-carousel-example).

Put the CSS at the top, either by linking to a .css file or including the CSS directly:

<head>
  <link href="./css/bootstrap.css" rel="stylesheet">
  <style>
    /* put your custom CSS here if you'd like, for instance... */
    .carousel { 
      margin: 1em; 
    }
  </style>

Inside the body section, put your Carousel HTML.  It’s kind of long so just check out the gist. Put the javascript at the bottom, either by linking to a .js file or else including it directly

<script src="./js/jquery.min.js"></script>
<script src="./js/bootstrap.min.js"></script>
<script type="text/javascript">
// Put your custom javascript options here, for instance...
$(document).ready(function() {
    $('.carousel').carousel({interval: 100});
    });
</script>
</body>

</html>

step 3: profit?

If you load the html file in your browser, magic should now happen.

For reference, you can download this zip file where everything is set-up already: bootstrap-carousel-example

step 4: customize

What if we want the images to cycle faster, or the images to not cycle at all?

Okay, I’ve already shown how you can select some of the built-in bootstrap options using javascript:

$(document).ready(function() {
    $('.carousel').carousel({interval: 100});
    });

You can select individual carousels on a page by naming the carousel

<div id="carousel-keyfeatures" class="carousel slide" data-interval="false">

and then using a more specific jquery call

$(document).ready(function() {
    $('.carousel-keyfeatures').carousel({interval: 100});
    });

Alternatively, if you want some option to apply to all carousels on a page / site, you can pull this code out into a separate file

./js/carousel-override.js

and include it in each HTML file

<script src="./js/carousel-override.js"></script>

A third way to change an the options on a carousel is to include it in the HTML, like so:

<div id="carousel-example-generic" class="carousel slide" data-ride="carousel" data-interval="false">

step 5: sweeter customizations!

Now, to make more custom modifications, I had to fiddle with the CSS. A few hours later, I made the modifications you can see at this gist. Alternatively, download the zip file and uncomment the line

<link href="./css/carousel-override.css" rel="stylesheet">

trouble-shooting tips (bugs!)

First, cool tools:

1) Use firefox or chrome’s powerful built-in developer tools. The default shortcut to bring them up is ctrl-shift-c (you actually can’t get rid of our change this shortcut easily, which is annoying).

You can delete things, edit things without refreshing the page or modifying files, and other wonderful tools.

Screenshot from 2015-01-21 16:44:34
Screenshot of Firefox’s “Inspector” tool in use.

2) Use a Javascript hint tool, such as http://jshint.com/.

If you just use the Console tool in Firefox Inspector to see the javascript error messages, it is fairly cryptic.

SyntaxError: missing ) after argument list

Tools like JSHint can provide some more helpful feedback about what went wrong.

bugs

these things tripped me up:

1) the Bootstrap website makes ( and { look very similar on my computer, so I skipped the curly brackets and used

$('.carousel').carousel( interval: 2000 )

instead of the correct

$('.carousel').carousel({ interval: 2000 })

UPDATE 03 April 2015

I filed a bug on github: https://github.com/twbs/bootstrap/issues/16225, or as follows:

Font in code blocks on http://getbootstrap.com/ does not distinguish { and ( clearly, can cause anguish for newcomers to javascript. Please remove the Courier New font fallback option. Just monospace works well.

In Detail

I was following the the example at http://getbootstrap.com/javascript/#carousel, and my brain removed the “extra parenthesis” I think, similar to how you don’t notice I doubled “the” in this sentence unless I point it out.

This is a screenshot of the bootstrap website “code” block font currently on my computer:
js-bootstrap-font

Please remove the courier new font fallback option. Just monospace works well.

 code, kbd, pre, samp {
   font-family: monospace;
 }

Results in the much-better

js-bootstrap-font-better

(Most open-source projects in have nice websites but no issue tracker nor contact info for their own website or their documentation, only for their github repo around the actual code, and it’s not always clear where to file a bug…)

END UPDATE

2) I didn’t realize I needed to include the jquery file first, so I got cryptic messages like “$ is undefined”.

3) I spent a while debugging a weird gap that left the rightmost controls in midair. It occurred when the browser window was too big. Turns out I needed to hardcode a max-width, which I just hardcoded to be slightly smaller than the smallest image width I had.

appendix

Here are the files used in this tutorial again:

Gist

bootstrap-carousel-example.zip

i am a meat reducer (some musings on not-vegetarianism)

(no, meat-reducer is not actually a thing)

Over the last year, I’ve been toying with reducing my meat intake. Here are the causes and the successive iterations I went through.

chickenstareoff

i won’t spend money on meat, but i will eat meat going to waste

The initial deciding factor was founding a company with one other person who didn’t eat much meat. I didn’t like meat that much anyway (too many dry chicken breasts I’d shoved down to avoid food waste), so when buying company rations it was easier to stockpile food we would both eat (ramen, frozen cheese pizza, frozen bean burritos, cake mix cake, cheetos… I had such a terrible diet. YET SO GREAT).

His general philosophy was to avoid spending money on meat while still prioritizing not wasting food. This seemed agreeable to me, since I dislike food waste more than I dislike killing animals by a wide margin. Fish were deemed okay to make a complete diet easier, and so company celebrations were at sushi restaurants (dubious from an ecological standpoint, honestly, since over-fishing is a big problem).

The other major point was to not take a stand, to got the opposite direction of evangelist vegans or vegetarians who believe they have the higher moral ground.

first dilemma

Chicken instant noodles uses chicken stock. But I dislike shrimp instant noodles. Is paying for chicken instant noodles okay?

I decided it was, because most places don’t stock vegetarian instant noodles.

second dilemma

I hosted a boatwarming  bbq party. Was it okay to buy meat burgers and hotdogs for my friends who no doubt would expect it to be there and might find eating veggie burgers weird and unfulfilling?

I decided it was, although I’ll probably try to avoid the situation in the future.

Apparently, in mixed-diet household house parties, the vegan person might supply the vegan food and the omnivores buys the meat for everyone else.

third dilemma

When treating someone to lunch or dinner, is it okay to pay for their meat selections? We took our interns out to lunch several times.

I decided it was okay.

what options are there: few!

It was fun to go to restaurants and see what the vegetarian options were. They’re often not great. For instance, dim sum, that favorite of my group of friends. Good luck filling yourself up on anything vegetarian at dim sum. Crispy taro thing? Filled with meat inside. Long noodles? Secretly has shrimp embedded inside.

it’s hard to remember at first

I would catch myself ordering my go-to dishes at restaurants and then go “Derp.”

leather and down

Then the question comes up. What about spending money on animal products? Leather work boots are comfy and weatherproof. Down jackets are nice and warm. I decided spending money on these was okay.

it’s hard to not eat meat even when i’m not buying it

1) There’s a lot of free food around MIT, usually not-vegetarian

2) When I visit my parents or when they visit me, they cook me large quantities of meat (maybe I will make an exception and declare to them I am a meat reducer next time…)

It’s hard to explain your dietary preferences or avoid talking about them when you make them arse complicated

I had to declare my food preferences for ordering company lunch. (My company, <15 people, is a mix of vegan, vegetarian, and omnivore). My first week at work, my parents had cooked me a large batch of meat, so I ate it every day. Additionally, there’s a decent amount leftover from company lunch and I try to divert everything from the trash, including the meat dishes.

I wasn’t sure how to explain that I’m sort-of vegetarian except where chicken noodles and food going to waste are concerned, since really, if you’re sort-of vegetarian, you’re not actually vegetarian.

what about deer killed by bow and arrow from a friend of a friend

I’m not joking, this actually came up. I decided that it was okay to eat this meat, since it was definitely not factory-farmed.

why?

enh, why not. A lot of my friends are into it, I don’t actually like meat that much, and factory farming is definitively terrible.

also it’s delicious

i really want an eggplant parmesan sandwich. SO DELICIOUSSS. and hummus and raisin bread. and saag paneer. mmm. quinoa, onions, and sweet potatoes. sweet potato pizza. nachos and cheese. microwaved frozen vegetarian dumplings.

these are all super-simple college cooking foods.

currently

At work, I sit halfway between the vegetarians and the omnivores and pick exclusively from the vegetarian side if I can reach it, but if there’s leftovers I’ll eat them meat and all.

I never buy meat at the grocery store nor at restaurants. If I’m treating someone, I’ll pay for their meat selection. If it’s free food, I’ll avoid eating meat unless I’m really hungry, since usually someone else will get around to eating it.

Currently, I am a meat-reducer.

 

2014: robots, sea kayaking/sailing/backpacking, alternative living, bioinformatics

mmm, nyancake!
mmm, nyancake!

…or something. I’m ignoring facebook’s attempt to summarize my life for the moment.

In review, I’d say it was a good year: lots of adventures, first time experiences, new friends. There were some ups and some downs. The downs are still intensely personal, so I apologize for not sharing them right now and only showing the highlight reel of my life.

alright, now that I’ve established this is a pretentious and obnoxious post meant for myself,

Firsts

first wedding attended, for my awesome friend-since-elementary-school, Alice

20140913_172940

 

first full-time job, with the awesome Curoverse

20141010_112152
sneakermail genomes!

first time cosplaying and sewing my own costume (holy FRICK that was a lot of work)

20140322_015701
lie ren
boston anime convention 2014
boston anime convention 2014

outdoors

  • sea kayaking out to an island and camping on it

20140615_084402

20140615_003510

  • winter hiking

20140201_141102

  • backpacking
20140520_114134
ponies!

20140520_114025

20140521_141100

  • bluewater sailing
first sighting of Boston while travelling north from Fairhaven
first sighting of Boston while travelling north from Fairhaven
night-time botoring (boat motoring), view of Boston
night-time botoring (boat motoring), view of Boston

robots

  • manufacturing and shipping robots (yes, we delivered our kickstarter on-time!) and teaching a class to close to 100 people
b7e89ff3656f06740838ecbf689ed628_large
final parts count before we seal and ship our robot kits
e89aa8f745748d37dfa3b73276656857_large
engineering notebook drawings from a student
02657e6993e2c51bcee89841b95b6f75_large
that student’s final project
    • making sweet point-and-click camera-controlled robots (with help from our wonderful interns), albeit they failed on kickstarter, they were still cool from a technical standpoint

dark-staffpick

 

(sorry about my face at the beginning, it’s cropped from a longer video)

alternative living

  • liveaboard
20140830_211154
my home for a few weeks
IMG_20140604_133856
what it looks like out of the water
  • tiny home
20140929_083155
we started with the bare trailer and installed radiant heating and insulation
plywood siding going up
plywood siding going up
tarpaper to weatherproof our structure
tarpaper to weatherproof our structure

Thankful

I find myself being thankful a lot.

Wallet stolen in Mexico? Well, I’m still happy, healthy, and well-educated so I can go home and make more money. Sick with a cold? Well, at least it’s an infrequent occurrence and I’m not living in constant pain like sufferers of lupus or lyme disease.  And I’m not in danger of losing my job, which is understanding of sick days.

It’s almost like my brain is on obnoxiously optimistic mode. Ah well, I’ll enjoy it while it lasts.

Upsides

the upsides of having been through something traumatic in my childhood (and also travelling extensively) and also having been suicidal:

I grew up thinking most people had something or other they were intensely passionate about. But many of my current friends seem adrift, uncertain what they care about or what they are qualified to do anything about. Perhaps there is nothing wrong with being adrift and open to different directions, but (due to societal expectations?) they often seem to be in a state of malaise.

My trauma forged me: it tore me down, but I survived it and am stronger for it. These childhood experiences give me a sense of purpose in life, an acute and visceral sense of the injustice in and sheer incomprehensibility of our lives.

Thinking about death daily for an extended period of time also puts a different perspective on things, for better or for worse. I’m very happy with my life at the moment, but thanks to my experiences with wishing to die, I feel a focus on making the most of my life and defining what matters to me. For whatever reason, the house with a picket fence and a dog, something easily within my grasp if I worked for it thanks to the advantages I live with, has no appeal to me. Similarly, my focus is not on finding a relationship, nor on hitting the next “milestones” in the conventional path of life (university, career, husband, children, retirement, death), but rather on finding my life.

This past year, I thought my point of living was to have adventures and explore the breadth of sensation and possible experiences in life — things I cannot experience once I am dead. I’m not sure what the theme of this upcoming year will be, but I suppose a year of relative stability (moving three times in six months sucks!) might not hurt.

things i’d like to accomplish in 2015:

  • publish a paper
  • figure out what I want to accomplish in ten years and analyze the things I should try to get there

crap (stuff) i liked

“However, I continue to try and I continue, indefatigably, to reach out. There’s no way I can single-handily save the world or, perhaps, even make a perceptible difference- but how ashamed I would be to let a day pass without making one more effort”.

-Isaac Asimov,  “The Relativity of Wrong”

(src)

“For me, I am driven by two main philosophies: know more today about the world than I knew yesterday and lessen the suffering of others. You’d be surprised how far that gets you.”

– Neil deGrasse Tyson

and one from pop culture

Every night I used to pray that I’d find my people, and finally I did on the open road.
We had nothing to lose, nothing to gain, nothing we desired anymore, except to make our lives into a work of art.

– Lana Del Rey, “Ride”

(src) (related 5 minute TED talk: A glimpse of life on the road)

For instance, on the planet Earth, man had always assumed that he was more intelligent than dolphins because he had achieved so much — the wheel, New York, wars and so on — whilst all the dolphins had ever done was muck about in the water having a good time. But conversely, the dolphins had always believed that they were far more intelligent than man — for precisely the same reasons.

-Douglas Adams

projects blog (nouyang)