UI Development
December 2, 2016
DIG
The Future OF CSS
Tools & Theory
PROBLEMS WITH CSS
- Global Scope
- Selector Specificity
- Loading Dependencies
- Dead Code Elimination
- Style Encapsulation
- Customization
BEM
.form { }
.form--theme-light { }
.form--simple { }
.form__input { }
.form__submit { }
.form__submit--disabled { }
INLINE STYLES
var styles = {
button: {
display: 'inline-block',
margin: 20,
padding: 20,
border: '1px solid black'
}
};
var Button = React.createClass({
render: function() {
return (
<button style=styles.button>Click me!</button>
);
}
});
React.render(<Button />, document.getElementById('button'));
ATOMIC CSS
<style>
.Fl\(end\) { float: right; }
.W\(30\%\) { width: 30%; }
.My\(1em\) { margin-top: 1em; margin-bottom: 1em; }
</style>
<div class="Fl(end) W(30%) My(1em) Fl(n)--xs W(a)--xs">
<div class="Bd Bgc(#0280ae):h C(#0280ae) C(#fff):h P(20px)">
Lorem ipsum
</div>
</div>
CSS MODULES
<style>
/* components/submit-button.css */
.normal { /* all styles for Normal */ }
.disabled { /* all styles for Disabled */ }
.error { /* all styles for Error */ }
.inProgress { /* all styles for In Progress */
</style>
<script>
/* components/submit-button.js */
import styles from './submit-button.css';
buttonElem.outerHTML = `<button class=${styles.normal}>
Submit</button>`
</script>
<button class="components_submit_button__normal__abc5436">
Processing...
</button>
WEB COMPONENTS
<style>
app-panel {
display: flex;
}
[is="x-item"] {
transition: opacity 400ms ease-in-out;
opacity: 0.3;
flex: 1;
text-align: center;
border-radius: 50%;
}
</style>
<app-panel>
<li is="x-item">Do</li>
<li is="x-item">Re</li>
<li is="x-item">Mi</li>
</app-panel>
THANK YOU!
Future of CSS
By webguyian
Future of CSS
- 674