Pitch: Escreva CSS em JS
Quero apresentar uma ferramenta que desenvolvi há alguns dias.
Escreva CSS utilizando todo o poder do JS. Passe funções para propriedades CSS.
Exemplo de uso da ferramenta :
let css = {
// Query selector. É executado sobre o elemento processado, afetando seus filhos
selector: ".green",
/*
Variáveis que podem ser acessadas dentro de properties usando function
Caso seja informado uma function, o retorno dela é acessado
*/
vars: {
// As function recebem o próprio objeto vars no argumento, que já vem com o elemento HTML
style: vars => vars.element.style,
// Isso não funciona pois width é informado em properties, que executa depois de vars
width: vars => vars.element.style.width
},
properties: {
backgroundColor: "green",
width: "200px",
height: "150px"
},
// Os query selectors em childs são executados sobre os elementos HTML filhos, afetando os netos
childs: [
{
selector: ".yellow", // A div yellow é filha de green e neta do body
vars: {
// A propriedade super acessa o vars do objeto pai
parentH: vars => vars.super.style.height,
// É possível acessar as variáveis do mesmo objeto (parentH), seguindo a sequencia de declaração
size: vars => `calc(${vars.parentH} * 0.6)`,
// Também é possível acessar o style do elemento pai dessa maneira
parentStyle: vars => vars.element.parentElement.style
},
properties: {
backgroundColor: "yellow",
rotate: "45deg",
width: vars => vars.size,
height: vars => vars.size,
position: "relative",
top: "20%",
left: "27%"
}
},
{
selector: ".blue",
properties: {
backgroundColor: "blue",
width: "80%",
height: "80%",
borderRadius: "50%",
position: "relative",
top: "10%",
left: "10%"
}
}
]
}