Fis3前端工程化之项目实战
Fis3项目
项目目录结构:
E:.
│ .gitignore
│ fis-conf.js
│ index.html
│ package.json
│ README.md
│
├─material
│
└─resource
├─css
├─images
└─js
├─lab
│ │
│ └─until
└─ui
项目要求:
1.雪碧图
2.代码模块化
3.预处理
4.md5戳
5.压缩资源
雪碧图
启用雪碧图插件,fis3已内置
fis.match('::package', {
spriter: fis.plugin('csssprites')
})
设置雪碧图的合并格式
fis.config.set('settings.spriter.csssprites', {
margin: 10, //图之间的边距
layout: 'matrix' //使用矩阵排列方式,默认为线性`linear`
});
预处理
因为使用的是less,所以需要预处理less文件
通过fis-parser-less
插件可以处理
安装npm install -g fis-parser-less
fis.match('*.less', {
parser: fis.plugin('less'),
rExt: '.css'
})
代码模块化
Mod.js
我这里使用的Mode.js,这个百度开发的一个独立的模块化库。
包裹JS
除了mode.js以外我们还需要npm install -g fis-hook-commonjs
来安装一个模块化"包裹"库。
它的作用就是将我们的js代码外面包裹一层,比如我们常用的:jquery.lazyload
通过fis-hook-commonjs包裹后:
define('resource/js/lab/jquery.lazyload', function(require, exports, module) {
//jquery.lazyload代码
});
然后通过require('resource/js/lab/jquery.lazyload')
这种形式就可以加载我们需要的库了。
设置是否包裹
当然这里我们可以通过fis-conf.js
来控制需要包裹的js。
//指定目录文件进行define包裹
fis.match('/resource/js/lab/**.js', {
isMod: true
})
通过isMode
这个属性即可,true意为包裹,false意为不包裹。
添加别名(谨慎使用)
当然常用的jquery的话,我们可以通过下面这种设置来添加别名等。
fis.hook('commonjs')
.match('/resource/js/lab/jquery.js', {
id: 'jquery'
})
调用var $=require('jquery')
控制打包顺序
//设置mod.js的优先级在打包文件的第一位
fis.match('/resource/js/lab/mod.js', {
packOrder: -100
})
这里是通过packOrder
来处理打包的顺序,值越小打包越靠前。-100比-99靠前。
资源合并
资源合并是我们常用的功能,这里我通过安装npm install fis3-postpackager-loader
这个库来处理静态文件文件的资源配置。
他会对页面的js,css进行扫描,处理我们需要的文件。
比如我们不想将jquery文件合并,我们可以在html页面中这么处理。
<script type="text/javascript" src="../resource/js/lab/until/interactive.js"></script><!--ignore-->
添加<!--ignore-->
这个标记即可。
这样页面的这个文件就不会被处理了。
启用fis3-postpackager-loader
fis.match('::package', {
postpackager: fis.plugin('loader')
});
我们的html文件会引入多个js,css。这样的话我们会将他们合并成单个文件,提高性能。
<script type="text/javascript" src="../resource/js/lab/until/interactive.js"></script>
<script type="text/javascript" src="../resource/js/lab/until/tabchange.js"></script>
<script type="text/javascript" src="../resource/js/ui/swip.js"></script>
<script type="text/javascript" src="../resource/js/ui/tab.js"></script>
<script type="text/javascript" src="../resource/js/ui/main.js"></script>
通过下面配置处理
//静态资源加载器配置 npm install fis3-postpackager-loader
//不想加载的引入资源使用<!--ignore-->标记
//合并页面js
//不进行任何配置 css,js的合并使用fis的pack
fis.match('::package', {
postpackager: fis.plugin('loader')
});
//对合并的aio.css进行处理 打包的会自动进行csssprites
fis.config.set('pack', {
'/static/js/index_aio.js': [
'**.js'
],
'/static/css/index_aio.css': [
'**.css',
'**.less'
]
});
这样处理打包后的static目录下情况:
├─css
│ index_aio.css
│ index_aio_z.png
│
└─js
index_aio.js
md5戳
给js,css添加md5戳,使用useHash
fis.media('prod')
.match('/static/**.{css,js}', {
useHash: true
})
压缩资源
fis.media('prod')
.match('/resource/**.js', {
optimizer: fis.plugin('uglify-js')
})
.match('/resource/**.{css,less}', {
optimizer: fis.plugin('clean-css')
})
.match('/static/**.png', {
optimizer: fis.plugin('png-compressor')
})
将js,css,png进行压缩。压缩器fis3已内置,不需要安装库。
最后
注意fis3的配置文件中的操作顺序会影响你需要的结果
Fis3前端工程化之项目实战的更多相关文章
- Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端
0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...
- 妙味WEB前端开发全套视频教程+项目实战+移动端开发(99G)
一共99GB的视频教程,全部存于百度网盘中,13个栏目,每个栏目里还划分有独立的小栏目 最基本的web前端学习介绍,到项目实战,再到移动端的开发,真正彻底掌握前端开发的精髓: 视频教程在线预览:(百度 ...
- angularJs项目实战!02:前端的页面分解与组装
自从上一篇文章到现在已经有将近一个月的时间,我将精力放在了前端页面分解与组装,和angularjs如何与jquery.bootstrap.D3等一系列其他类库结合使用的经验总结上.由于公司新招了一些员 ...
- Python Django CMDB项目实战之-3创建form表单,并在前端页面上展示
基于之前的项目代码 Python Django CMDB项目实战之-1如何开启一个Django-并设置base页.index页.文章页面 Python Django CMDB项目实战之-2创建APP. ...
- Python Django CMDB项目实战之-2创建APP、建模(models.py)、数据库同步、高级URL、前端页面展示数据库中数据
基于之前的项目代码来编写 Python Django CMDB项目实战之-1如何开启一个Django-并设置base页index页文章页面 现在我们修改一个文章列表是从数据库中获取数据, 下面我们就需 ...
- Spark大型电商项目实战-及其改良之番外(1)-将spark前端页面效果高效拷贝至博客
Spark大型电商项目实战-及其改良这个系列的时间轴展示图一直在变....1-3篇是用图直接表示时间轴,用一段简陋的html代码表示时间表.第4篇开始才是用比较完整的前端效果,能移动.缩放时间轴,鼠标 ...
- Asp.Net Core 2.0 项目实战(3)NCMVC角色权限管理前端UI预览及下载
Asp.Net Core 2.0 项目实战(1) NCMVC开源下载了 Asp.Net Core 2.0 项目实战(2)NCMVC一个基于Net Core2.0搭建的角色权限管理开发框架 Asp.Ne ...
- 前端开发工程师 - 06.Mini项目实战 - 项目简介
第6章--Mini项目实战 项目简介 Mini项目简介-Ego社区开发 回顾: 页面制作 页面架构 JavaScript程序设计 DOM编程艺术 产品前端架构 实践课Mini项目--Ego: 主题:漫 ...
- 强烈推荐 GitHub 上值得前端学习的开源实战项目
强烈推荐 GitHub 上值得前端学习的开源实战项目. Vue.js vue-element-admin 是一个后台前端解决方案,它基于和 element-ui 实现 基于 iView 的 Vue 2 ...
随机推荐
- [原] KVM 虚拟化原理探究(1)— overview
KVM 虚拟化原理探究- overview 标签(空格分隔): KVM 写在前面的话 本文不介绍kvm和qemu的基本安装操作,希望读者具有一定的KVM实践经验.同时希望借此系列博客,能够对KVM底层 ...
- VisualStudio2013 如何打开之前版本开发的(.vdproj )安装项目
当你的项目使用早于 visualstudio2013 的版本开发并且使用 Visual Studio Installer 制作安装项目时,在升级至 VS2013 后会发现新安装项目无法打开, VS20 ...
- WPF做12306验证码点击效果
一.效果 和12306是一样的,运行一张图上点击多个位置,横线以上和左边框还有有边框位置不允许点击,点击按钮输出坐标集合,也就是12306登陆的时候,需要向后台传递的参数. 二.实现思路 1.获取验证 ...
- scrapy 知乎用户信息爬虫
zhihu_spider 此项目的功能是爬取知乎用户信息以及人际拓扑关系,爬虫框架使用scrapy,数据存储使用mongo,下载这些数据感觉也没什么用,就当为大家学习scrapy提供一个例子吧.代码地 ...
- 用scikit-learn学习谱聚类
在谱聚类(spectral clustering)原理总结中,我们对谱聚类的原理做了总结.这里我们就对scikit-learn中谱聚类的使用做一个总结. 1. scikit-learn谱聚类概述 在s ...
- 初识的Spring Mvc-----原理
一.Spring Mvc简介 Spring Mvc(Spring Web Mvc) 属于表现层的框架. 二.Spring结构图 Spring Mvc是Spring框架里面web模块的一部分,是在Spr ...
- Sass之坑Compass编译报错
前段时间在使用Compass时遇到了其为难处理的一个坑,现记录到博客希望能帮助到各位. 一.问题: 利用Koala或者是gulp编译提示如下,截图为koala编译提示错误: 二.解决办法 从问题截图上 ...
- css3更改input单选和多选的样式
在项目开发中我们经常会遇到需要更改input单选和多选样式的情况,今天就给大家介绍一种简单改变input单选和多选样式的办法. 在这之前先简单介绍一下:before伪类 :before 选择器向选定的 ...
- CSS常见技巧
一.CSS Sprite(雪碧图|精灵图)指什么? 有什么作用? CSS雪碧 即CSS Sprite,也有人叫它CSS精灵,是一种CSS图像合并技术,该方法是将小图像和背景图片合并到一张图片上,然后利 ...
- 【干货分享】流程DEMO-外出申请
流程名: 外出申请 流程相关文件: 流程包.xml 流程说明: 直接导入流程包文件,即可使用本流程 表单: 流程: 图片:2.png DEMO包下载: http://files.cnblog ...