吾日三省吾身。css
从一个彻底不相干的行业转到IT,多多少少都会感到迷茫,不知道学习什么、从何学起?在几乎没有任何经验的背景下,坚持投递简历,最后终于进入了一个创业公司,开始作起了前端工做。工资勉强维持生活。工做之余,也在不停的学习。html
项目web页面可能是用的jsp,项目组leader对html、css、js这块也不甚了解,因此大多数时候都是本身去研究怎么搞。前端
每次版本更新的时候都会遇到缓存的问题,而后本身就去找解决方案,而后就发现了fis3(http://fis.baidu.com/)这个前端构建工具,感受还挺好用,又适合如今的项目。node
基本用法也很简单:jquery
fis.match('*.{css,js,png,jpg}', { useHash: true })
能够自行控制匹配项,有些文件不必定须要加文件指纹,能够web
fis.match('{reset.css,jquery.js}', { useHash: false })
b. 资源压缩
一般须要压缩的资源有css样式文件,js文件,图片等npm
// css样式文件 fis.match('*.css', { // fis-optimizer-clean-css插件已内置 optimizer: fis.plugin('clean-css') }) // js文件 fis.match('*.js', { // fis-optimizer-uglify-js插件已内置 optimizer: fis.plugin('uglify-js') }) // png格式图片文件 fis.match('*.js', { // fis-optimizer-png-compressor插件已内置,该插件不支持10.xx版本的node,因此须要用的的建议不要升级node optimizer: fis.plugin('png-compressor') })
c. 雪碧图
fis3能够对背景图片自动进行雪碧图合并,写样式的时候,后面加上?__sprite
浏览器
li.list1 { background-image: url('./img/list-1.png?__sprite'); } li.list2 { background-image: url('./img/list-2.png?__sprite'); }
// 首先启用fis-spriter-csssprites 插件 fis.match('::package', { spriter: fis.plugin('csssprites') }) // 对设置了?__sprite的背景图片合并 fis.match('*.css', { useSprite: true })
d. sass、less预编译器
sass:须要先安装fis-parser-node-sass插件
npm install -g fis-parser-node-sass缓存
fis.match('*.scss', { parser: fis.plugin('node-sass'), rExt: '.css', useHash: true // 能够直接在这里添加md5戳 });
less:须要先安装fis-parser-less插件
npm install -g fis-parser-lesssass
fis.match('*.less', { parser: fis.plugin('less'), rExt: '.css' })
页面中的样式文件仍然引用原文件
<link rel="stylesheet" href="./css/XXX.less"> <link rel="stylesheet" href="./css/XXX.scss">
d. 预览与文件监听
fis3内置server,可使用命令
fis3 server start 开启内置服务器,默认8080端口,fis3 server stop 关闭服务器。
使用命令
fis3 release -wL 将项目发布到内置服务器,并开启文件监听,在编辑器中修改代码,保存后会在浏览器(推荐使用Chrome)实时更新。
若是静态资源的访问路径与项目根路径不一致,可使用url配置
fis.match('*.{png,js,jpg,css,scss}', { url: '/src/pages$0' })
这样就基本知足一个多页面web项目的要求了。
添加了md5戳,不再须要担忧缓存问题了