之前我写过一篇文章,大意是测试同学可以适当的学一学前端。前端技术里面,依赖相对较少的可能就是 css 了。
那如何学习 css 呢?作为一个半吊子的 css 的使用者,我发现其实大家经常使用到的 css 属性其实是有限的,能不能有什么办法来统计一下哪些属性是重要且必须掌握的呢?所以就萌发了统计重要的 css 属性的想法。
首先需要考虑的问题是,什么样的属性算是重要属性。一般来说,大家使用频率比较高的属性应该是重要且必须掌握的了。
后来的问题就是,如何统计这些属性的使用频率呢?其实可以从分析流行的 css 框架中的属性做起。先选定一些 css 框架,下载对应的 css 文件,然后从文件里拿到所有的属性,统计其对应的出现次数,频繁出镜的属性可以认为是重要的了。
有了思路,那就开始做吧。
我随便选择了一些 css 框架
上面这些框架没有个人喜好,就是根据 github 的 star 数随便选的。
下载的话用脚本去做就好了,不需要手工搞。
# https://cdnjs.com/libraries/twitter-bootstrap
wget https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.1.3/css/bootstrap.css
# https://cdnjs.com/libraries/bulma
wget https://cdnjs.cloudflare.com/ajax/libs/bulma/0.7.1/css/bulma.css
# https://cdnjs.com/libraries/foundation
wget https://cdnjs.cloudflare.com/ajax/libs/foundation/6.4.3/css/foundation.css
# https://cdnjs.com/libraries/materialize
wget https://cdnjs.cloudflare.com/ajax/libs/materialize/1.0.0/css/materialize.css
# https://cdnjs.com/libraries/pure
wget https://cdnjs.cloudflare.com/ajax/libs/pure/1.0.0/pure.css
# https://cdnjs.com/libraries/semantic-ui
wget https://cdnjs.cloudflare.com/ajax/libs/semantic-ui/2.3.3/semantic.css
一般来说,css 的语法是这样的
.kls {
width: 100%;
}
我们可以发现,一般来说,有;
出现的行就是 css 属性出现的行,所以第一步就是过滤出所有包含;
的行,那就用grep
吧。
找到所有包含;号的行之后,我们还需要使用:
来切割该行,输出第 1 列,也就是属性名称列。这里用的是cut
。
拿到属性名称之后,做一些梳理,比如去掉开头的空格之类的,再使用sort + uniq
,排序加去重。
完整的 shell 命令如下
cat *.css | grep ';' | tr -d ' ' | cut -d ':' -f 1 | sort | grep -v "^-" | grep -v "^/"| grep -v "^\."| grep -v "^\*"|grep -v "^@"| grep -v "^\s"|uniq -c | sort -r > all.txt
这时候就拿到了临时输出文件 all.txt
head all.txt
248 color
248 background-color
237 display
134 margin-left
114 border-color
89 padding
85 max-width
85 margin-bottom
81 width
80 flex
数字代表 css 属性出现的次数。
github 可以直接浏览 markdown 文件,用 html 的方式,因为每个属性大家可能都需要去搜索引擎里搜索具体用法,为了简单专业起见,我用直接拼出了每个属性再 mdn 中对应的地址,方便大家学习。
输出 markdown 文件的代码很简单。
file_name = 'all.txt'
with open(file_name) as f:
content = f.read()
for line in content.split("\n"):
times_and_attr = line.strip().split(' ')
if len(times_and_attr) == 2:
print('* %s [%s](https://developer.mozilla.org/en-US/docs/Web/CSS/%s)' %(times_and_attr[0], times_and_attr[1], times_and_attr[1]))
用 python 代码去解析 all.txt,然后把输出重定向到 markdown 文件。
python make_doc.py > reference.md
./download.sh # 下载css文件
./attr.sh *.css > all.txt # 输出临时文件
python make_doc.py > reference.md # 创建md文件
希望对大家有所帮助。
另外一些使用频率不高的 css 属性其实也非常重要。比如 box-sizing,在统计结果中只出现了 3 次,但实际上却是相当重要的属性。
微信公众号读者请点击阅读原文查看。