Skip to content

blenderbox/html-boilerplate

Repository files navigation

Boiling hot HTML Boilerplate

Blenderbox Guidelines for HTML, CSS, and JavaScript

Blenderbox HTML boilerplate

Last edited 09.15.2014

INTRODUCTION

This document is a list of guidelines, tips, and examples for creating HTML, JavaScript and CSS for Blenderbox projects. Where applicable, please follow these guidelines to create a clean, SEO friendly website that adheres to Blenderbox's best practices.

1.0 - HTML

  • Use the default package for directory structure and the base styles.
  • Do not use in-line JavaScript and never use in-line CSS.
  • Keep scripts at the bottom of the page and CSS links in the head of the page to help with page load performance.
  • Do not use tables when you can avoid it, and most likely, you can avoid it.
  • Make sure all images have an alt attribute.

2.0 - CSS

  • Do not make the CSS overly complicated, but rather let the styles cascade where reasonable and applicable while using as little mark up as necessary.
  • When starting a project, begin by styling the basic HTML elements. If no design is provided for that, please confirm that it is not needed.
  • Make sure all links and buttons have a rollover state. If you cannot find a rollover or on state in a PSD, please contact project management and let them know and they will provide you with one.
  • Don't use ID's #hotdrama - Id selectors have priority over other kinds of selectors. This can make it harder to add new rules using less specific selectors, leading to specificity wars: http://www.stuffandnonsense.co.uk/archives/css_specificity_wars.html
  • Be consistent with indentation
  • Be consistent about where spaces before/after colons/braces go
  • One selector per line, One rule per line
  • Use lowercase and dashes for classes.

Example:

.weather {
  background: LightCyan;
}

.weather > h3 {
  border-bottom: 1px solid white;
}

2.1 - CSS Preprocessor (Sass/Less) Style Guide

  • List @extend(s) First - Knowing right off the bat that this class inherits another whole set of rules from elsewhere is good.
  • List "Regular" Styles Next
  • List @include(s) Next - This visually separates the @extends and @includes as well as groups the @includes for easier reading. You might also want to make the call on separating user-authored @includes and vendor-provided @includes.
  • Nested Selectors Last

Example:

.weather {
  @extends %module;
  background: LightCyan;
  @include transition(all 0.3s ease);

  > h3 {
    border-bottom: 1px solid white;
    @include transform(rotate(90deg));
  }
}
  • All Vendor Prefixes Use @mixins
  • Maximum Nesting: Three Levels Deep - Chances are, if you're deeper than that, you're writing a crappy selector. Crappy in that it's too reliant on HTML structure (fragile), overly specific (too powerful), and not very reusable (not useful). It's also on the edge of being difficult to understand.

Example:

.weather {

  .cities {

    li {
      // no more!
    }
  }
}
  • Partials are named _partial.scss - This is a common naming convention that indicates this file isn't meant to be compiled by itself. It likely has dependancies that would make it impossible to compile by itself. Personally I like dashes in the "actual" filename though, like _dropdown-menu.scss.
  • Variablize All Common Numbers, and Numbers with Meaning
  • Variablize All Colors

3.0 JavaScript

Use the module pattern

var APP = (function($, undefined) {
    'use strict';

    var app = {},
        $el;

    // define public functions
    app.foo = function() {  };

    // define private functions
    function init() {
        // Init the plugin
    }
    // Call the init function on load
    $(init);
    return app;
} (jQuery));

Only use one var declaration and put each variable on its own line

var a,
    b,
    z;

Use the exactly equal to (equal value and equal type) instead of ==

Example:

    1 === '1'

Don't leave extra spaces.

Validate your JavaScript with a linter such as http://www.jshint.com/ which can be installed as a plugin in most editors.

3.0 - TIPS TO FOLLOW

Some of the common issues with browser compliance as well as the Blenderbox standards can be found below.

  • Use the line-height attribute when vertically aligning a single line of text or input field. This is often helpful when styling footers etc.
  • Write the CSS with a hierarchical approach. For instance, if the header element appears on the top of the page, put the header element at the top of the CSS file.
  • All label tags attributes should be set to the value of the input field id so a user can click the label to select the field. All fields should have a label if there is design for it.

CLEARING

We have two options for clearing, first the clearfix class and second the clear class. You can read more about the clearfix here http://www.webtoolkit.info/css-clearfix.html The basic clearing class, .clearfix, uses the ‘:after’ pseudo-selector to add clearing after the tag you are floating. To clear after a floated element, you can use clearfix.

Examples of clearing after:

<div class=”clearfix”>
  <div class="float-left">
    Content that is floating
  </div>
</div>

If you need to use a block element to clear a float, please use a div with a non-breaking space.

Examples:

<div class=”float-left-class”></div>
<div class=”clear”>&nbsp;</div>

BUTTONS

Use the button tag because it can be more reliably styled in every browser

<button type="submit"></button>

IMAGES

  • Cut out as much white-space from an image as you can.
  • Save .png files instead of .gif files when you can.
  • Save .gif files when there are few colors or the image is a vector to optimize for performance and quality.
  • Save .jpg files at 'High' in the Save for Web settings when using Photoshop.
  • All images should have alt tags describing the image.

4.0 - Template Delivery

  • Please make sure the CSS and HTML on all pages validates. You can use the HTML5 validator to address any issues http://html5.validator.nu/
  • Test the files in IE8+, Firefox, Chrome, and Safari.

5.0 - The default file directory

/fonts

/images

/javascripts
    /app - All page specific Javascripts go here.
        application.js - All application wide JavaScript goes here.
            This is where you start the JavaScript development.

    /libs – A folder with libraries written by someone else. jQuery, modernizer, should be here.
        If you add new libraries, place them here.

        jquery-{version}.min.js – the jQuery library.
        log.js - Add logging support to browsers without console.log
        modernizr-{version}.min.js – A JavaScript library for HTML5 tests. 
            http://modernizr.com/download/#-input-shiv-cssclasses-load
            This should be included in the Head of your page to add HTML5 elements to IE.
            Review the file to see what tests are available and visit the website if you 
            need to add more tests.
        request_interval.js - a shim for request animation support.

    simple-plugin-template.jquery.js – A simpler jQuery plugin template.

/stylesheets
    all.css

index.html – A basic file for starting the site with most relevant HTML elements for style.
humans.txt – Read more: http://goo.gl/IjffW
robots.txt – Read more: http://goo.gl/JzIqS

6.0 - IE Targeted Styles

If you want to style for IE specifically, use the following classes that are added to the HTML node via conditional statements and Modernizr.

IE7 - lt-ie8 IE8 - lt-ie9

.lt-ie8 body { background:lime; }
.lt-ie9 body { background:pink; }

To target browsers that do not have JavaScript support, use the no-js class.

.no-js body { background:light-blue; }

7.0 Icons

We use icon fonts for our icons. To generate them, use icomoon Select the icons you want or upload SVGs of the icons you need and the select download. On the download screen, change the font name to 'icons', check 'encode and embed font in css,' and select 'use class selector.' Then download the font and store the zip in your project in case someone needs to make changes to it later by uploading the selection.json file to icomoon.

Generate all the icons you need for every devise here realfavicongenerator.net

8.0 Compiling

We are compiling the SASS into one file with npm and Grunt). We assume you have npm installed.

Install grunt client with

sudo npm install -g grunt-cli

Assuming that the Grunt CLI has been installed, it's very easy to start working with Grunt:

Change to the project's root directory.

Install project dependencies with

npm install

Run Grunt with

grunt

That's really all there is to it. Installed Grunt tasks can be listed by running grunt --help.

About

Base HTML and CSS for beginning a project for Blenderbox

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published