使用 gulp 验证更少,包括 BEM
Validate less with gulp including BEM
所以我有一个相当大的代码库,它使用更少(很多文件)。我想将 css 转换为使用 BEM(实际上是 BEM 的一个变体),我很想找到一种 gulp 方法来检查 less 文件,包括命名约定。
有什么办法吗?
所以基本上我想要所有默认的 css lint 东西并另外定义可能不会被破坏的命名约定。
例如类需要以c-、u-或o-开头,其他类是不允许的。
如果像 https://github.com/necolas/postcss-bem-linter 这样的后处理器由于某种原因不能为您工作。您可以编写自己的插件,也可以创建一个 Less 插件。 Less plugin可以是visitors也可以是postprocess,自己用。
E.g. classes need to start with c-, u- or o-, other classes are not permitted.
检查上述要求的访客插件示例:
<!DOCTYPE html>
<html>
<head>
<title>BEM Validation</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link type="text/css" href="bem.less" rel="stylesheet/less">
<script>
var ValidateBEM = function(less) {
this._visitor = new less.visitors.Visitor(this);
};
ValidateBEM.prototype = {
isReplacing: true,
run: function (root) {
return this._visitor.visit(root);
},
visitRuleset: function (rulesetNode, visitArgs) {
console.log(visitArgs);
if(rulesetNode.selectors) {
for (var i = 0; i < rulesetNode.selectors.length; i++) {
if(rulesetNode.selectors[i].elements[0].value.match(/^\./)){
if(!rulesetNode.selectors[i].elements[0].value.match(/^\.[cuo]-/))
{
console.log(rulesetNode.selectors[i].elements[0]);
throw { type: 'BEM Validation',
message: "class names should start with c-, u- or o-",
filename: rulesetNode.selectors[i].elements[0].currentFileInfo.filename,
index: rulesetNode.selectors[i].elements[0].index };
}
}
}
}
return rulesetNode;
}
};
var ValidateBEMPlugin = {
install: function(less, pluginManager) {
pluginManager.addVisitor(new ValidateBEM(less));
}
};
less = {
env: "development",
plugins: [ValidateBEMPlugin]
};
</script>
<script src="//cdnjs.cloudflare.com/ajax/libs/less.js/2.4.0/less.min.js"></script>
</head>
<body>
<header>
<h1>header</h1>
</header>
</body>
</html>
当bem.less
包含以下class时:
.class {
t:test;
}
上面的内容将导致如下所示的错误:
Grunt-contrib-less 也允许您使用 Less 插件:
less: {
production: {
options: {
paths: ["assets/css"],
plugins: [
new (require('less-plugin-bem'))({browsers: ["last 2 versions"]}),
] }
}
}
上面使用的插件只能在浏览器中使用,参见如何创建CLI版本。
所以我有一个相当大的代码库,它使用更少(很多文件)。我想将 css 转换为使用 BEM(实际上是 BEM 的一个变体),我很想找到一种 gulp 方法来检查 less 文件,包括命名约定。
有什么办法吗?
所以基本上我想要所有默认的 css lint 东西并另外定义可能不会被破坏的命名约定。
例如类需要以c-、u-或o-开头,其他类是不允许的。
如果像 https://github.com/necolas/postcss-bem-linter 这样的后处理器由于某种原因不能为您工作。您可以编写自己的插件,也可以创建一个 Less 插件。 Less plugin可以是visitors也可以是postprocess,自己用。
E.g. classes need to start with c-, u- or o-, other classes are not permitted.
检查上述要求的访客插件示例:
<!DOCTYPE html>
<html>
<head>
<title>BEM Validation</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link type="text/css" href="bem.less" rel="stylesheet/less">
<script>
var ValidateBEM = function(less) {
this._visitor = new less.visitors.Visitor(this);
};
ValidateBEM.prototype = {
isReplacing: true,
run: function (root) {
return this._visitor.visit(root);
},
visitRuleset: function (rulesetNode, visitArgs) {
console.log(visitArgs);
if(rulesetNode.selectors) {
for (var i = 0; i < rulesetNode.selectors.length; i++) {
if(rulesetNode.selectors[i].elements[0].value.match(/^\./)){
if(!rulesetNode.selectors[i].elements[0].value.match(/^\.[cuo]-/))
{
console.log(rulesetNode.selectors[i].elements[0]);
throw { type: 'BEM Validation',
message: "class names should start with c-, u- or o-",
filename: rulesetNode.selectors[i].elements[0].currentFileInfo.filename,
index: rulesetNode.selectors[i].elements[0].index };
}
}
}
}
return rulesetNode;
}
};
var ValidateBEMPlugin = {
install: function(less, pluginManager) {
pluginManager.addVisitor(new ValidateBEM(less));
}
};
less = {
env: "development",
plugins: [ValidateBEMPlugin]
};
</script>
<script src="//cdnjs.cloudflare.com/ajax/libs/less.js/2.4.0/less.min.js"></script>
</head>
<body>
<header>
<h1>header</h1>
</header>
</body>
</html>
当bem.less
包含以下class时:
.class {
t:test;
}
上面的内容将导致如下所示的错误:
Grunt-contrib-less 也允许您使用 Less 插件:
less: {
production: {
options: {
paths: ["assets/css"],
plugins: [
new (require('less-plugin-bem'))({browsers: ["last 2 versions"]}),
] }
}
}
上面使用的插件只能在浏览器中使用,参见