fis3-postpackager-loader插件说明
fis3-postpackager-loader
静态资源前端加载器,用来分析页面中使用的和依赖的资源(js或css), 并将这些资源做一定的优化后插入页面中。如把零散的文件合并。
注意
此插件做前端硬加载,适用于纯前端项目,不适用有后端 loader 的项目。因为不识别模板语言,对于资源的分析和收集,比较的粗暴!!!
默认会把页面中用到的样式插入在 header 中,脚本插入在 body 底部。如果想修改,请在页面自己插入<!--SCRIPT_PLACEHOLDER--> 和 <!--STYLE_PLACEHOLDER--> 占位符来控制位置。
此插件会收集所有的资源,如果希望某个资源不被收集,请在资源结尾处如 </script> 后面加上 <!--ignore--> 注释.
<script src="lib.js"></script><!--ignore-->
注意:被 ignore 的资源,不会被修改位置,同时也不会参与 allInOne 合并。
安装
支持全局安装和局部安装,根据自己的需求来定。
npm install fis3-postpackager-loader
使用
fis.match('::packager', {
postpackager: fis.plugin('loader', {
allInOne: true
})
});
文件属性
默认 loader 只会以 html 的方式处理后缀为 .html 的文件,如果希望其他后缀也以 html 的方式去处理,请设置 loaderLang 属性。
fis.match('*.md', {
loaderLang: 'html'
});
处理流程说明
如果你真的很关心的话,以下详细的流程处理介绍。
先假定所有优化功能全开,处理流程如下:
- 遍历所有的 html 文件,每个文件单独走以下流程。
- 分析 html 内容,插入注释块
<!--SCRIPT_PLACEHOLDER-->到</body>前面,如果页面里面没有这个注释块的话。 - 分析 html 内容,插入注释块
<!--STYLE_PLACEHOLDER-->到</head>前面,如果页面没有这个注释的话。 - 分析源码中
<script>带有 data-loader 属性的或者资源名为[mod.js, require.js, require.js]的资源找出来,如果有的话。把找到的 js 加入队列,并且在该<script>后面加入<!--RESOURCEMAP_PLACEHOLDER-->注释块,如果页面里面没有这个注释的话。 - 分析源码中
<script>带有 data-framework 属性的资源找出来。把找到的 js 加入队列。 - 分析此 html 文件的依赖,以及递归进去查找依赖中的依赖。把分析到的 js 加入到队列,css 加入到队列。
- 分析此 html 中
<script>、<link>和<style>把搜集到的资源加入队列。 - 启用 allinone 打包,把队列中,挨一起的资源合并。如果是内联内容,直接合并即可,如果是外链文件,则合并文件内容,生成新内容。
- 把优化后的结果,即队列中资源,插入到
<!--SCRIPT_PLACEHOLDER-->、<!--STYLE_PLACEHOLDER-->和<!--RESOURCEMAP_PLACEHOLDER-->注释块。
那么 js 的输出顺序就是:带 data-loader 的js,带 resource map 信息的js, 带 data-framework 的js,依赖中的 js, 页面中其他 js.
也就是说,如果你发现资源的加载顺序不符合你的预期时,请加适当的属性来调整资源级别。
疑问解释
什么是页面依赖?
分两种方式指定依赖:
通过 fis 中的注释指定依赖。
<!--@require "xxx.js"-->
更多用法,请查看声明依赖
通过 js 语句指定依赖。
require('./main');表示此代码所在的文件,依赖当前目录下面的 main.js 文件。
另外依赖又分两种性质,以上都是同步依赖,还有一种异步依赖。
require(['./main']);
同步js 是页面加载时加载,而异步js 依赖则是运行时加载,能满足按需加载的需求。
什么是 js loader
fis 中对依赖的js 加载,尤其是异步 js,需要一个 js loader。比如 mod.js 是一个 loader, require.js 也是一种 loader。
什么是 resourcemap ?
当有异步依赖的时候,为了让 loader 知道文件所在位置,所以需要需要 resourcemap 信息。
此插件能生成两类 resourcemap.
给 mod.js 用的,格式如下:
require.resourcemap({
res: {...},
pkg: {...}
})给 require.js amd loader 用的,格式如下:
require.config({
paths: {
...
}
})
配置说明
scriptPlaceHolder默认<!--SCRIPT_PLACEHOLDER-->stylePlaceHolder默认<!--STYLE_PLACEHOLDER-->resourcePlaceHolder默认<!--RESOURCEMAP_PLACEHOLDER-->resourceType默认 'auto', 可选'mod'、'amd'。allInOne默认 false, 配置是否合并零碎资源。allInOne 接收对象配置项。
cssall in one 打包后, css 文件的路径规则。默认为pkg/${filepath}_aio.cssjsall in one 打包后, js 文件的路径规则。默认为pkg/${filepath}_aio.jsincludeAsyncs默认为 false。all in one 打包,是不包含异步依赖的,不过可以通过把此属性设置成 true,包含异步依赖。ignore默认为空。如果不希望部分文件被 all in one 打包,请设置 ignore 清单。
processor默认为{'.html': 'html'}, 即支持后缀是 .html 的文件,如果要支持其他后缀,请在此扩展。fis.match('::package', {
postpackager: fis.plugin('loader', {
processor: {
'.html': 'html', // 支持 markdown 文档
'.md': 'html'
}
})
})obtainScript是否收集<script>内容。(非页面依赖部分)obtainStyle是否收集<style>和<link>内容。(非页面依赖部分)useInlineMap是否将 sourcemap 作为内嵌脚本输出。resoucemap默认为/pkg/${filepath}_map.js当useInLineMap为false的时候有效,用来控制 resourcemap 生成位置。include默认生成的 sourcemap 只会包含异步依赖的 js, 如果想把一批模块化的 js 加入到 sourcemap 中,请参考一下配置:fis.match('::package', {
postpackager: fis.plugin('loader', {
include: '/widget/a/**.js'
})
}) fis.match('::package', {
postpackager: fis.plugin('loader', {
include: [
'/widget/**.js',
'!/widget/a/**.js'
]
})
})
fis3-postpackager-loader插件说明的更多相关文章
- webpack的像素转vw loader插件
这是一款针对webpack的像素转vw单位的loader插件. 笔者公司中,h5 rem的开发方案目前已经渐渐开始转向vw方案,因此本工具应运而生. 目前所制作的h5,大部分设计稿分辨率都是750的宽 ...
- node作为前台的项目如何打包静态js和css并生成版本号,loader插件的使用
一.使用场景: 1.node创建的前台项目需要输入地址展示页面 2.有设置缓存或者cdn的需要在静态文件更改时能使用新的而不是缓存的,需要版本号这里 3.可能需要压缩静态文件的 二.一些参考地址,需要 ...
- 使用jquery的lazy loader插件实现图片的延迟加载
当网站上有大量图片要展示的话,如果一次把所有的图片都加载出来的话,这势必会影响网站的加载速度,给用户带来比较差的体验.通过使用jquery的lazy loader插件可以实现图片的延迟加载,当网页比较 ...
- webpack的像素转vw单位的loader插件
安装: npm i px2vw-view-loader 配置: 按以下loader格式,添加进入webpack配置文件,实现从px转换成vw,适用于移动端项目 module: { rules: [{ ...
- fis3前端工程构建配置入门教程
一.前言 fis3是百度推出的一款前端工程构建工具,类似的还有webpack,gulp等工具:无论大家有没有使用过,从事前端行业应该都略知一二了,所以对于此类工具用干嘛的我这里就不做重复了. 其实对于 ...
- FIS3中使用less
安装插件: npm install -g fis-parser-less npm install -g fis3-postpackager-loader 配置:fis-conf.js 使用fis-pa ...
- requirejs的插件介绍与制作
本文由作者郑海波授权网易云社区发布. 前言 我这里就不介绍requirejs了, 简而言之: requirejs是支持AMD规范的模块加载器, 事实上它也是AMD的最直接推动者. 现在可供挑选的开源模 ...
- 【cocos2d-js官方文档】九、cc.loader
概述 原来的cc.Loader被改造为一个单例cc.loader,采用了插件机制设计,让loader做更纯粹的事. 各种资源类型的loader可以在外部注册进来,而不是直接将所有的代码杂揉在cc.Lo ...
- 【webpack插件使用】在开发中快速掌握并使用Webpack构建web应用程序
1.webpack-dev-server插件的基本使用 入门程序 const path = require('path'); // 导出一个Webpack的配置对象(通过node中的模块操作,向外暴露 ...
- FIS 插件机制
FIS 插件机制 author: @TiffanysBear 当我们使用 FIS 插件的时候,有没有想过自己也开发一个基于 FIS 的插件,参与 FIS 打包编译的整个流程:那么问题就来了: FIS ...
随机推荐
- 1.5---字符串压缩(CC150)
import java.util.*; public class Zipper { public String zipString(String str) { // write code here i ...
- 转:SQL子句的执行顺序
SQL 不同于与其他编程语言的最明显特征是处理代码的顺序.在大数编程语言中,代码按编码顺序被处理,但是在SQL语言中,第一个被处理的子句是FROM子句,尽管SELECT语句第一个出现,但是几乎总是最后 ...
- mysql 日志文件mysql-bin文件清除方法,和mysql-bin相关文件的配置
默认情况下mysql会一直保留mysql-bin文件,这样到一定时候,磁盘可能会被撑满,这时候是否可以删除这些文件呢,是否可以安全删除,是个问题. 首先要说明一下,这些文件都是mysql的日志文件,如 ...
- JavaScript——特殊点总结
首先,== equality 等同,=== identity 恒等. ==, 两边值类型不同的时候,要先进行类型转换,再比较. ===,不做类型转换,类型不同的一定不等. 下面分别说明: 先说 === ...
- fstream的使用方法介绍
转载自: fstream的使用方法介绍 - saga's blog - C++博客 http://www.cppblog.com/saga/archive/2007/06/19/26652.html ...
- Python之调用WebService:suds
suds官方: https://fedorahosted.org/suds/wiki/Documentation 互联网公开WSDL: http://www.webxml.com.cn/zh_cn/w ...
- Failed to issue method call: Unit httpd.service failed to load: No such file or directory.
centos7修改httpd.service后运行systemctl restart httpd.service提示 Failed to issue method call: Unit httpd.s ...
- nginx服务器设置url的优雅链接
对于LNMP这样架构的网站来说,一般都是基于php框架开发,php框架一般都会讲究优雅链接,比如Laravel,CodeIgniter,ThinkPHP等都是支持这种链接模式的,在服务器配置上也叫作u ...
- SolrCloud的官方配置方式
前面写过生产过程中的SolrCloud集群配置,实际上官方给出的是免安装配置,启动时采用命令行参数的方式启动,这样相对简单,并且官方文档也给出了外部Zookeeper的配置,和前面说的基本一致,这个不 ...
- Slave SQL: Error 'Incorrect string value ... Error_code: 1366
背景: 主从环境一样,字符集是utf8. Slave复制报错,平时复制都正常也没有出现过问题,今天突然报错: :: :: :: :: Error_code: :: perror 1366 MySQL ...