The following document outlines a reasonable style guide for CSS development. These guidelines strongly encourage the use of existing, common, sensible patterns. They should be adapted as needed to create your own style guide.
This is a living document of Best Practices and Code Standards for Front-End Development at O3 World. The Development Team is encouraged to test, discuss, and evolve what is documented here together as best practices change and new ideas are shared. Please implement and enforce these agreed upon standards in your own builds and in code reviews at all times for all projects.
Well-formed markup is made up of part standards and part agreed upon preferences by a team of developers. Along with consistency, both are important in creating maintainable, readable code for everybody.
An .editorconfig file is included with this documentation to aid in enforcing some of these standards. A full breakdown of the current .editorconfig
is provided later in this document.
The Table of Contents below will help jump you to the pertinent section of this Code Standards document:
There are several guiding principles with Code Standards. These represent the core concepts of standardized code and why we use this document to guide development best practices.
- Code should be readable and understandable by all members of the team. This includes internal and external developers.
- All code, regardless of the project, should read as if it was developed by a single person regardless of how many individuals actually worked on it.
- The style of writing and implementation of these Code Standards is agreed upon and implemented by the team.
- Assist in developing well-formed, semantically correct, and mostly valid code.
- Aid in the onboarding of new development team members to new and existing projects.
When developing, readability is preferred over compression. There is no need for a developer to purposefully (manually or automatically) compress HTML or CSS/SCSS, nor obfuscate JavaScript (more details provided in JavaScript Code Standards).
Automation tools such as Gulp are used to combine and minify CSS and JavaScript assets as needed. Verbosity is preferred in original source code.
- Always be consistent in your use of whitespace using it to improve code readability.
- Use soft tabs with four spaces.
Our .editorconfig file helps with maintaining proper whitespace in different files.
Well commented code is extremely important. Take time to describe components, how they work, their limitations, and the way they are constructed. Don't leave others in the team guessing as to the purpose of uncommon or non-obvious code.
HTML (Hyper Text Markup Language) acts as the Structure or skeleton for which our Presentation (Styles) and Functionality (JavaScript) are built on. This makes it the foundation of the other components of our Front-End. It’s semantics can have a either a positive, or negative, impact on:
- Browser Rendering Speed
- Search Engine Optimization (SEO)
- Accessibility (a11y)
- Validation
- Usability
Filenames should contain lowercase letters and words should be separated with a hyphen. The hyphen word separator (as opposed to an underscore or camelcase) is considered good practice for SEO reasons.
HTML5 provides us with lots of semantic elements aimed to describe precisely the content - take advantage of its rich vocabulary. Make sure you understand the semantics of the elements you're using.
NOTE: It's worse to use a semantic element in a wrong way than staying neutral.
Good developers can write valid HTML markup that is formatted properly and easy to read. Great developers go beyond that and know when to use the appropriate element for the job.
- Attribute values, even numeric attributes, should be quoted. Even though quotes around attributes are optional, always put quotes around attributes for readability. Always use double quotes, never single quotes, on attributes.
- DO NOT include a trailing slash in self-closing elements - the HTML5 spec defines this as optional. These self-closing elements include:
<hr>
<br>
<input>
<img>
- DO NOT omit optional closing tags (e.g.
</li>
or</body>
). - Element and attribute names should all be lowercase.
- Nested elements should be indented once (four spaces).
- Classes are preferred over IDs when it comes to CSS references to avoid specificity issues. More details on Class Naming Conventions are below.
<!-- bad -->
<body>
<img src='../path/file' alt='Alternative Text' />
<ul id='myList'>
<li>
This is the first part of some sample text before a break.
<br />
More text after the break.
<li>Just another list item in the middle of two others.
<li>The final list item.
</ul>
<hr />
<form>
<label>Form Label</label>
<input type=text placeholder='Sample Input' />
<input type=submit value='Submit' />
</form>
<!-- good -->
<body>
<img src="../path/file" alt="Alternative Text">
<ul class="my-list">
<li>
This is the first part of some sample text before a break.
<br>
More text after the break.
</li>
<li>Just another list item in the middle of two others.</li>
<li>The final list item.</li>
</ul>
<hr>
<form>
<label>Form Label</label>
<input type="text" placeholder="Sample Input">
<input type="submit" value="Submit">
</form>
</body>
All HTML code must be valid and well formed. A validator can often help a developer track down styling or scripting bugs. Valid HTML also increases the likelihood that a page will be displayed correctly in current and future browsers.
Tools such as The W3C Markup Validation Service or PowerMapper’s SortSite can be used to test code validation as well as other aspects of development.
Enforce standards mode and more consistent rendering in every browser possible with this simple doctype at the beginning of every HTML page.
<!DOCTYPE html>
<html>
<head>
...
</head>
</html>
From the HTML5 spec (<html lang="en-us">
):
Authors are encouraged to specify a lang attribute on the root html element, giving the document's language. This aids speech synthesis tools to determine what pronunciations to use as well as aids translation tools to determine what rules to use.
Quickly and easily ensure proper rendering of your content by declaring an explicit character encoding. When doing so, you may avoid using character entities in your HTML, provided their encoding matches that of the document (generally <meta charset="UTF-8">
).
<!DOCTYPE html>
<html lang="en-us">
<head>
<meta charset="UTF-8">
...
</head>
</html>
Starting HTML5 markup is included with this documentation (based on HTML5 Boilerplate) with a fully formed and valid skeleton for front-end development.
Per the HTML5 spec, typically there is no need to specify a type when including CSS and JavaScript files as text/css
and text/javascript
are their respective defaults.
<!-- external CSS -->
<link rel="stylesheet" href="my-styles.css">
<!-- in-document CSS -->
<style>
/* ... */
</style>
<!-- javascript -->
<script src="my-javascript.js"></script>
HTML attributes should come in this particular order for easier reading of code.
src
,for
,type
,href
,value
class
id
,name
title
,alt
role
,aria-*
data-*
<a href="#" class="..." id="..." data-toggle="modal">
Example Link
</a>
<input type="text" class="form-control">
<img src="..." class="..." alt="...">
As far as Identifiable information is concerned, Classes make for great reusable components, so they come first. IDs are more specific and should be used sparingly (e.g., for in-page bookmarks), so they come after Classes.
XHTML required you to declare a value for all attributes, but HTML5 has no such requirement for boolean attributes. A list of some of these boolean attributes includes:
- autofocus
- selected
- checked
- disabled
- readonly
- multiple
- required
- novalidate
- formnovalidate
<input type="text" disabled>
<input type="checkbox" value="1" checked>
<select>
<option value="1" selected>1</option>
</select>
The W3C Spec for Boolean Attributes has additional information on these boolean attributes.
Writing markup in a JavaScript file makes the content harder to find, harder to edit, and less performant. Avoid it whenever possible.
Insert an ending comment after the closing tag of a long HTML section. This helps to identify what named element is being closed. DO NOT use a starting comment.
<div class="my-class">
...
</div>
<!-- /.my-class -->
Basic accessibility principles should be adhered to when writing HTML - it shouldn't be an afterthought. You don't have to be a WCAG expert and different clients have different requirements for level of support, but basic accessibility support can have a huge impact.
- Use
H1
-H6
to properly order and identify headings. - In tables, use the
scope
attribute to associate header cells and data cells in data tables and use thesummary
attribute of the table element to give an overview of data tables. - For forms, always provide a submit button, use
label
elements to associate text labels with form controls, and visually indicate required form controls. - With image elements, always use
alt
attributes. Use an emptyalt
attribute on image elements that Assistive Technology should ignore.- Good
alt
attribute text should describe the content of the image as specifically as possible. - If an image is used for decorative purposes only, an
alt=""
should be used.
- Good
- Text should NEVER be included as part of an image even when using and
alt
attribute to describe it. - Inline
svg
elements should includetitle
and, as needed,desc
elements to provide alternative titles and descriptions.- The
title
element must be the first child of it's parent element. This provides a human readable name for the SVG content. - A
desc
element may be added to describe the SVG. Consider addingdesc
elements to describe complex SVGs such as charts or process maps. - If an SVG image is purely decorative, do not include a title or description. Decorative SVG elements should be identified as presentational by adding the ARIA attributes
aria-hidden="true"
androle="presentation"
.
- The
For additional information on writing good alt
attribute text, check out What is Alt Text (Alternative Text)? by Moz.
Tools such as PowerMapper’s SortSite or Chrome’s Accessibility Developer Tools extension can be used to audit and correct basic accessibility issues.
Unless there's a valid reason for loading your scripts before your content (e.g. Modernizr or certain tracking scripts), don't block the rendering of your page by placing them in the <head>
. Move as many as possible to the bottom of the markup right above the </body>
or async
/defer
the load.
Individual SVG assets should be optimized using a tool such as SVGOMG. Image assets should be processed using a tool like ImageOptim. Both of these safely remove - without a noticeable change to the asset - redundant and useless information such as editor metadata, comments, hidden elements, default or non-optimal values which can have a significant impact on file size.
The default Gulp setup has been configured to combine and minify CSS and JavaScript into as few files as possible, but it can be configured to suit the unique needs of individual projects.
Representing the Presentation layer of our Front-End Development, it’s important that our CSS/SCSS is well organized and documented. One of CSS’ best features - cascading - can also be its biggest achilles.
A .stylelintrc.json file is included with this documentation to aid in enforcing some of these standards. A full breakdown of the current .stylelintrc.json
is provided later in this document.
Filenames should contain lowercase letters and words should be separated with a hyphen.
- Within individual CSS/SCSS files, organize sections of code by component element.
- Maintain a consistent commenting hierarchy for each section of code.
- Use consistent white space to your advantage when separating sections of code for scanning larger documents.
The top-level SCSS should serve as a “Table of Contents” with no styles directly within it. Keep all styles organized into component parts. When ordering your partials within your “Table of Contents”, the ideal order/grouping is:
- Global
- Vendor
- Elements
- Components
- Sections
- Pages
Partials are named _partial-name.scss
- with a "_" prefix - to indicate that this file isn't meant to be compiled by itself. Break CSS/SCSS down by component instead of page. Pages can be rearranged and components (re)moved.
There is no penalty to splitting into many small files. It’s much easier to jump to small specific files and navigate through them than fewer/larger ones.
// global
@import 'global/functions';
@import 'global/variables';
// vendor
@import 'vendor/bootstrap/bootstrap';
// elements
@import 'partial/grid';
@import 'partial/utility';
// components
@import 'partial/modals';
@import 'partial/tabs';
// sections
@import 'partial/global-footer';
@import 'partial/global-header';
// pages
@import 'partial/contact-page';
Source Maps are produced as part of our Gulp build to more easily determine where particular SCSS partial rules are coming from to aid in visual debugging within the browser.
The overall structure of a SCSS rule should follow the below order:
- Extends and Includes
- Always place
@extend
and@include
statements on the first lines of a declaration block. - Knowing right off the bat that this class inherits another set of rules from elsewhere is good and overriding styles for that inherited set of rules becomes much easier.
- Always place
- Regular Styles
- Adding our regular styles after
@extend
and@include
allows us to properly override those properties, if needed. - To support a mobile-first cascade, the styles that are defined first represent the "base" or smallest screen look. Media Queries are added after our Regular Styles to build on or modify the "base" look.
- Adding our regular styles after
- Pseudo Class’ and Elements
- Pseudo Class’ and Pseudo Elements directly relate to the element itself so we nest them first before other selectors.
- Differentiate between Pseudo Elements and Pseudo Classes by using a double colon versus a single colon, respectively (
my-class::before { … }
versusmy-class:hover { … }
).
- Nested Selectors
- This includes any modifiers and children of the class we’re working within.
.my-module {
@extend %module;
@include font-size(16);
background: #0f0;
text-transform: uppercase;
@media screen and (min-width: 768px) {
background: #f00;
text-align: center;
}
&:hover {
background: #0c0;
}
&::before {
display: block;
content: '';
}
> h3 {
@include transform(rotate(90deg));
border-bottom: 1px solid #fff;
@media screen and (min-width: 768px) {
border-bottom: 0;
text-transform: uppercase;
}
}
}
As a rule of thumb, avoid unnecessary nesting in SCSS. At most, aim for three levels. If you cannot help it, step back and rethink your overall strategy (either the specificity needed, or the layout of the nesting). This prevents overly-specific CSS selectors.
CSS/SCSS formatting decisions documented below are in place to ensure that code is: easy to read; easy to clearly comment; minimizes the chance of accidentally introducing errors; and results in useful diffs and blames:
- When grouping selectors, keep each selector to a single line.
- Include one space before the opening brace of declaration blocks for legibility.
- Place closing braces of declaration blocks on a new line.
- Include one space after the
:
for each declaration. - Each declaration should appear on its own line for more accurate error reporting.
- End all declarations with a semicolon. The last declarations semicolon is optional, but your code is more error prone without it.
- Comma-separated property values should include a space after each comma (e.g.,
box-shadow
). - Don't include spaces after commas within
rgb()
,rgba()
,hsl()
,hsla()
, orrect()
values. This helps differentiate multiple color values (comma, no space) from multiple property values (comma with space). - Don't prefix property values or color parameters with a leading zero (e.g.,
.5
instead of0.5
and-.5px
instead of-0.5px
). - If you need transparency, use
rgba()
. Otherwise, always use the hexadecimal format. - Lowercase all hex values (e.g.,
#fff
). Lowercase letters are much easier to discern when scanning a document as they tend to have more unique shapes. - Use shorthand hex values where available (e.g.,
#fff
instead of#ffffff
). - Use single quotes consistently (e.g.,
content: '';
). - Quote attribute values in selectors (e.g.,
input[type='text']
). They’re only optional in some cases, and it’s a good practice for consistency. - Avoid specifying units for zero values (e.g.,
margin: 0;
instead ofmargin: 0px;
). - Separate each ruleset by a blank line.
- Don't make values and selectors hard to override. Minimize the use of id's and avoid
!important
. - For improved readability, wrap all math operations in parentheses with a single space between values, variables, and operators.
.selector-1,
.selector-2,
.selector-3[type='text'] {
display: block;
box-shadow: 0 1px 2px #ccc;
background: #fff;
background: linear-gradient(#fff, rgba(0,0,0, .8));
font-family: helvetica, arial, sans-serif;
color: #333;
&::before {
position: absolute;
padding: 0;
content: '';
}
}
.selector-a {
padding: (10px * 2) 5px;
}
.selector-b,
.selector-c { padding: 10px; }
Adding vendor prefixes for CSS properties is unnecessary since Gulp uses Autoprefixer to only post-process vendor prefixes based on the declared browser support. The unique browsers supported can be updated on a project basic.
Long, comma-separated property values - such as collections of gradients or shadows - can be arranged across multiple lines in an effort to improve readability and produce more useful diffs.
.selector-1 {
display: block;
box-shadow: 0 1px 2px #ccc,
inset 0 1px 0 #fff;
}
In instances where a rule set includes only one declaration it may optionally be placed on a single line. When grouping single line selectors consider removing line breaks for readability and faster editing. Any rule set with multiple declarations should be split to separate lines.
.span1 { width: 60px; }
.span2 { width: 140px; }
.span3 { width: 220px; }
Related property declarations should be grouped together following the below general order:
- Box Sizing
box-sizing
- Position
z-index
position
top
right
bottom
left
- Display
display
- Flex
flex
flex-basis
flex-direction
flex-flow
flex-grow
flex-shrink
flex-wrap
align-content
align-items
align-self
justify-content
- Grid
grid
grid-area
grid-template
grid-template-areas
grid-template-rows
grid-template-columns
grid-column
grid-column-start
grid-column-end
grid-row
grid-row-start
grid-row-end
grid-auto-rows
grid-auto-columns
grid-auto-flow
grid-gap
grid-row-gap
grid-column-gap
- Order
order
- Columns
columns
column-gap
column-fill
column-rule
column-rule-width
column-rule-style
column-rule-color
column-span
column-count
column-width
- Float
float
clear
- Margin
margin
margin-top
margin-right
margin-bottom
margin-left
margin-collapse
margin-top-collapse
margin-right-collapse
margin-bottom-collapse
margin-left-collapse
- Outline
outline
outline-offset
outline-width
outline-style
outline-color
- Box Shadow
box-shadow
- Border Radius
border-radius
border-top-right-radius
border-top-left-radius
border-bottom-right-radius
border-bottom-left-radius
- Border
border
border-top
border-right
border-bottom
border-left
border-width
border-top-width
border-right-width
border-bottom-width
border-left-width
- Border Style
border-style
border-top-style
border-right-style
border-bottom-style
border-left-style
- Border Color
border-color
border-top-color
border-right-color
border-bottom-color
border-left-color
- Border Image
border-image
border-image-source
border-image-width
border-image-outset
border-image-repeat
border-image-slice
- Padding
padding
padding-top
padding-right
padding-bottom
padding-left
- Width
width
min-width
max-width
- Height
height
min-height
max-height
- Overflow
overflow
overflow-x
overflow-y
resize
- Background
background
background-attachment
background-clip
background-color
background-image
background-repeat
background-position
background-size
- Cursor and Events
cursor
pointer-events
- svg
fill
stroke
- List Style
list-style
list-style-type
list-style-position
list-style-image
caption-side
- Counters
counter-reset
counter-increment
- Tables
table-layout
border-collapse
border-spacing
empty-cells
- Visibility
opacity
visibility
- Vertical Alignment
vertical-align
- Text Alignment and Decoration
direction
tab-size
text-align
text-align-last
text-decoration
text-decoration-color
text-decoration-line
text-decoration-style
text-justify
text-indent
text-transform
text-rendering
text-shadow
text-overflow
- Text Spacing
line-height
letter-spacing
word-spacing
white-space
word-break
word-wrap
- Font
font
font-family
font-size
font-size-adjust
font-stretch
font-weight
font-smoothing
osx-font-smoothing
font-variant
font-style
- Color
color
- Animation
animation
animation-name
animation-duration
animation-timing-function
animation-delay
animation-iteration-count
animation-direction
animation-fill-mode
animation-play-state
- Transform
backface-visibility
perspective
perspective-origin
transform
transform-origin
transform-style
- Transition
transition
transition-delay
transition-duration
transition-property
transition-timing-function
- Content
content
quotes
- Breaks
page-break-before
page-break-after
page-break-inside
- Misc
hyphens
src
clip
filter
size
zoom
appearance
user-select
interpolation-mode
marks
page
set-link-source
unicode-bidi
speak
Positioning comes first because it can remove an element from the normal flow of the document and override box model related styles. The box model comes next as it dictates a component's dimensions and placement.
Everything else takes place inside the component or without impacting the previous two sections, and thus they come last.
.declaration-order {
/* positioning */
z-index: 100;
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
/* display and box-model */
display: block;
float: right;
margin: 0;
outline: 1px solid #f00;
box-shadow: 0 5px 5px #000;
border-radius: 50%;
border: 1px solid #999;
padding: 0;
width: 100px;
height: 100px;
overflow: hidden;
background-color: #f5f5f5;
opacity: 1;
visibility: visible;
vertical-align: middle;
/* typography */
text-align: center;
text-decoration: underline;
line-height: 1.5;
font: normal 13px 'Helvetica Neue', sans-serif;
font-size: 14px;
color: #333;
/* misc */
transform: translateX(10px);
transition: color #f00;
content: '';
appearance: none;
}
NOTE: A comprehensive property order breakdown can be viewed in the custom .stylelintrc.json
file. Properties that are delared out of the order defined in this file will be flagged with a warning during linting.
Use REMs with a pixel fallback for font-size
, because it offers absolute control over text. Additionally, a unitless line-height
is preferred because it does not inherit a percentage value of its parent element, but instead is based on a multiplier of the font-size
.
font-size
and line-height
mixins are available and will generate a REM value with a Pixel fallback.
Well commented code is extremely important. Take time to describe components, how they work, their limitations, and the way they are constructed. Don't leave others in the team guessing as to the purpose of uncommon or non-obvious code.
- Each SCSS partial should have a clear comment header to define the role of this section of code.
- Place comments on a new line above their subject.
- Keep line-length to a sensible maximum (e.g. 80 columns).
- Make liberal use of comments to break SCSS code into discrete sections.
- Use "sentence case" comments and consistent text indentation.
/*
* Comment Header
*
*****************************************************************************/
/*
* Detailed Comment Header
*
* This is some text the describes, in detail, how the below SCSS works, any
limitations, and the way it is constructed.
*
* 1. Targeted notations can be included as well if inline comments aren't
sufficient to outline functionality
*
*****************************************************************************/
/*
* Child Comment
*
*********************************************************/
/* Single line comment */
Pre-formatted comment chunks can be setup within most IDEs and tied to a keyboard shortcut to more easily apply consistent formatting.
- Avoid excessive and arbitrary shorthand notation.
.btn
is useful for button, but.s
doesn't mean anything. - Use meaningful names; use structural or purposeful names over presentational.
- It's also useful to apply many of these same rules when creating SCSS variable names.
Block Element Modifier (BEM) is a highly useful, powerful, and simple naming convention that makes your front-end code easier to read and understand, easier to work with, easier to scale, more robust and explicit, and a lot more strict.
The BEM approach ensures that everyone who participates in the development of a website works with a single codebase and speaks the same language - exactly what we’re looking for! Using BEM’s proper naming convention will better prepare you for design changes made to your website.
The naming convention follows this pattern:
.block { ... }
.block__element { ... }
.block--modifier { ... }
.block
represents the higher level of an abstraction or component..block__element
represents a descendent of.block
that helps form.block
as a whole..block--modifier
represents a different state or version of.block
.
An analogy/model for how elements are related:
.media { ... }
.media__img { ... }
.media__img--rev { ... }
.media__body { ... }
<div class="media">
<img src="logo.png" class="media__img media__img--rev" alt="Foo Corp logo">
<div class="media__body">
<h3 class="h2">Welcome to Foo Corp</h3>
<p class="lede">Foo Corp is the best, seriously!</p>
</div>
</div>
CSS classes or IDs as references for JavaScript functionality should be avoided as much as possible to prevent conflicts where renaming or removing a class or ID name would break JavaScript functionality.
Instead use data-*
attributes to apply JavaScript functionality to elements and components exclusive of styling applied by classes. This data-*
attribute should be namespaced to the element or component where you are applying functionality.
If, for instance, you are applying data-*
attributes to a mobile primary navigation with toggle buttons and flyout panels, you might use a naming convention like:
data-nav="container"
data-nav="toggle"
data-subnav="container"
data-subnav="toggle"
Use your best judgement or ask a fellow developer if your namespacing makes sense. TL;DR Naming is hard.
Use the .is-*
prefix for state classes that are shared between CSS/SCSS and JavaScript to denote a temporary styling application.
<div class="accordion-tab is-active" data-accordion="true">
...
</div>
The sass-lint linter is no longer maintained, so O3 is dropping active support for sass-lint. Previous sass-lint docs can be viewed here
A custom .stylelintrc.json
file has been setup and included with this documentation to aid in the implementation of these standards. It will provide Warnings and Errors within the console for you to review and correct. This stylelint config extends the stylelint recommended config, and uses an additional stylelint-order plugin for property sorting.
To see a list of the rules, refer to the stylelint-config-standard as well as the rules in the .stylelintrc.json
file in this repository
npm install stylelint stylelint-config-standard stylelint-order --save-dev
- Copy
.stylelintrc.json
from this repo and into project root.
Stylelint CLI can autofix as many errors as possible. To use the autofixer append --fix
to a stylelint command.
stylelint "foo/*.scss" --fix
All items (Warnings and Errors) should be addressed to be inline with Front-End Standards defined in this document.
A full breakdown of all available Rules in the SASS Linter are available with the Documentation.
NOTE: There are instances where exceptions to these linting rules are necessary. In those instances, individual file, rule, and declaration exceptions can be added. A breakdown of these exception comments is below:
Disable a rule for the entire file
/* stylelint-disable declaration-no-important */
p {
margin: 0 !important; // No lint reported
}
Disable more than 1 rule
/* stylelint-disable declaration-no-important, string-quotes */
p {
margin: 0 !important; // No lint reported
content: "hello"; // No lint reported
}
Disable a rule for a single line
p {
margin: 0 !important; /* stylelint-disable-line declaration-no-important */
}
Disable and enable again
/* stylelint-disable selector-no-id, declaration-no-important */
#id {
color: pink !important;
}
/* stylelint-enable */
a {
border: 0; // Failing result reported
}
Disable/enable all linters
/* stylelint-disable */
p {
margin: 0 !important; // No result reported
}
/* stylelint-enable */
a {
margin: 0 !important; // Failing result reported
}
An image that has informational value should be a part of the markup and include an appropriate alt
attribute - more on proper alt
attribute implementation can be found in Accessibility.
If an image is purely decorative (it provides no content value other than visual flair to the page) then a background-image
is appropriate. An inline image can also be used, but with the appropriate ARIA and role
attributes applied.
<img src="../path/to/image/file.jpg" alt="" aria-hidden="true" role="presentation"
These attributes should also be applied when defining an inline SVG icon that is used for presentational purposes only. Learn More about SVG Accessibility.
<svg class="u-icon-search-dims" aria-hidden="true" role="presentation">
<use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#search"></use>
</svg>
These attributes cascade down the tree, so any markup that might appear within the container where they are declared will also be considered not for screen reader use.
An EditorConfig helps developers define and maintain consistent coding styles between different editors and IDEs. This will help avoid common code inconsistencies and dirty diffs due to differences in editor formatting.
A few items pre-set in the .editorconfig
file:
root = true
- Says that this file represents the top-most .editorconfig file and settings here should be applied.
[*]
denotes that the following settings will be applied to all files:indent_style = space
- Use a soft space character for indents.
indent_size = 4
- A single indent is equal to 4 spaces.
end_of_line = lf
- Unix-style line breaks.
charset = utf-8
- Use the UTF-8 character set.
trim_trailing_whitespace = true
- Removes any whitespace characters at the end of each line.
insert_final_newline = true
- Adds a new, blank line to the end of our file.
[*.md]
is specific to files with this extensiontrim_trailing_whitespace = false
- Do Not remove any trailing whitespace from lines.
- The indent size used in the
package.json
file cannot be changed, so we have specific settings for this file type:[{.travis.yml,package.json}]
indent_size = 2
indent_style = space
# .editorconfig helps developers define and maintain consistent coding
# styles between different editors and IDEs
# for more information about the properties used in this file, please see
# the .editorconfig documentation: http://editorconfig.org/
# this is the top-most .editorconfig file; do not search parent directories
root = true
# applied to all files
[*]
indent_style = space
indent_size = 4
end_of_line = lf
charset = utf-8
trim_trailing_whitespace = true
insert_final_newline = true
[*.md]
trim_trailing_whitespace = false
# the indent size used in the `package.json` file cannot be changed
# https://github.com/npm/npm/pull/3180#issuecomment-16336516
[{.travis.yml,package.json}]
indent_size = 2
indent_style = space
These Code Standards are the culmination of research into best practices as well as input from the Development team. Specifics are adapted from various sources, including:
Will fix code to adhere to a predefined configuration file. The .csscomb file in this repository is set to fix scss to adhere to stylelint settings.
- Copy .csscomb file from this repo in the root of your project.
- Install the CSScomb plugin to your IDE (see links below)
- Follow instructions from the plugin to configure the plugin.