cssobj plugin to extend selector to another selector, like @extend in SCSS or $extend in LESS.
- npm
npm i cssobj-plugin-extend
Then
var cssobj = require('cssobj')
var cssobj_plugin_extend = require('cssobj-plugin-extend')
// then consume the cssobj_plugin_extend below
cssobj(obj, {
plugins: [ cssobj_plugin_extend(option) ]
})
var obj = {
'p': {
fontSize: '12px'
},
div:{
$extend: 'p',
color: 'red'
}
}
Result css:
p,div { font-size: 12px; }
div { color: red; }
var obj = {
'.blue': {
color: 'blue'
},
'p': {
fontSize: '12px'
},
div:{
$extend: ['p', '.blue'],
color: 'red'
}
}
Result css:
.blue,div { color: blue; }
p,div { font-size: 12px; }
div { color: red; }
var obj = {
// clearfix hack
'.clearfix': {
'&:before, &:after': {
content: '" "',
display: 'table'
},
'&:after': {
clear: 'both'
},
'&': {
'*zoom': 1
}
},
div:{
$extend: /\.clearfix/,
color: 'red'
}
}
Result css:
.clearfix:before, .clearfix:after,div:before, div:after {
content: " ";
display: table;
}
.clearfix:after,div:after {
clear: both;
}
.clearfix,div {
*zoom: 1;
}
div { color: red; }
return function as cssobj plugin.
Default value: $extend, which means the intended key checking by this plugin is $extend
, you can set it to any value start with '$'
.
var obj = {
p: {color: 'red'},
div: {$ext: 'p'}
}
// use $ext as keyName
cssobj(obj, {plugins: [cssobj_plugin_extend({keyName: '$ext'})]})
cssobj version >= 0.5.5
MIT