0.1.11 • Published 8 years ago

edp-build-versioning v0.1.11

Weekly downloads
2
License
MIT
Repository
github
Last release
8 years ago

edp-build-versioning

EDP Build plugin for Resource Versioning

edp-build-versioning 是 edp-build的一个插件,用于为 esl requireJSTPL 资源自动添加MD5版本号信息,也支持为 CSSJS图片 等内联资源文件自动添加 MD5版本号 信息。

关于edp支持的版本号处理方案及关于 Versioning 处理器实现方案一个简单探讨,参见这个 Issue

如何使用

Install

npm install edp-build-versioning

Config

  1. edp-build-config.js 文件里,添加该处理器:

    注意: 处理器放的位置,最好放在倒数第二个处理器前,确保计算 md5 值能正确反应文件内容变化。

    exports.getProcessors = function () {
    
        var Versioning = require('edp-build-versioning');
        var versionProcessor = new Versioning({
            // 要添加版本号的内联资源文件路径
            filePaths: [
                'src/common/a.js',
                'src/common/css/main.less'
            ],
    
            // 自动扫描所有css为其引用添加版本号
            // autoScanCss: true,
    
            // 为 css url 引用的的资源文件添加版本号
            cssURL: true,
            // 也可以指定特定的资源
            // cssURL: ['src/img/sprite.png'],
            
            // 是否使用重命名文件方式而非查询参数方式,对于 `require` 只有 `combine` 开启时候
            // 才会重写模块的文件名称
            // rename: true,
            
            // 输出的md5摘要长度,默认8位
            // md5Length: 10,
    
            require: {
                // 要生成的路径前缀的版本号信息最大路径前缀深度,为了避免生成
                // 的路径前缀信息较多,理想情况下,每个文件对应的路径都生成,
                // 对于项目文件较多,将导致如下生成版本号信息太多,影响页面
                // 加载及 esl require 的效率,因此建议控制下深度值
                pathPrefixDepth: 2,
                
                // 只针对模块配置文件的 combine 配置的合并模块id和定制的模块id(值为数组情况)
                // 生成模块版本号信息
                combine: true|['a/b', 'c'],
    
                // require 资源生成的版本号信息输出地方
                output: '\'esl_resource_version\'',
                
                // 可以指定模块默认使用的版本号信息, 默认版本号为时间戳
                // 页面中加上该配置项:require.config({ urlArgs: 'default_resource_version' });
                defaultOutput: 'default_resource_version',
                
                // 当使用 `combine` 且是多页面情况下,启用该选项,只会生成当前页面所引用入口模块
                // 的版本号信息
                outputByPage: true
            }
            
            // 也可以自定义版本号生成器
            // require: {
            //   version: function (processFiles) {
            //      // 简单返回时间戳作为所有资源的版本号 也可以自行返回 路径前缀的版本号 map
            //      return Date.now();
            //      // return {'a/b': 'v=123'};
            //   },
            //   output: '\'esl_resource_version\''
            // }
            
            // 也可以将版本号信息输出到特定的文件
            // require: {
            //    pathPrefixDepth: 2,
            //    output: 'src/version.js'
            // }
    
        });
    
        // init EDP Build other processors
    
        return {
        
            // 用于开发调试测试环境,执行 edp build -f 即可
            default: [
                lessCompiler,
                cssCompressor,
                moduleCompiler,
                tplMerger,
                versionProcessor,
                pathMapper
            ],
    
            // 用于线上环境,执行 edp build -f -s release
            release: [
                lessCompiler,
                cssCompressor,
                moduleCompiler,
                tplMerger,
                new JsCompressor(),
                versionProcessor,
                pathMapper
            ]
        };
    }
  2. require.config 里配置要输出的版本号信息位置:

    require.config({
        'baseUrl': 'src',
        'urlArgs': 'esl_resource_version'
        // other config
    });

    如果打算把版本号输出到特定的文件里,version.js 文件为空文件即可,在入口的 html 文件 添加如下引用,注意放在 require.config 前面:

    <script src="src/version.js"></script>
    <script>
       require.config({
           'baseUrl': 'src',
           'packages': [
           ]
       });
       
    </script>   

Build

执行 edp build 后,urlArgs 值会替换成类似如下的值,由于路径深度为 2 因此下面最长只会看到 a/b 这种前缀的版本号信息:

require.config({
    'baseUrl': 'src',
    'urlArgs': {
        '05522e67.tpl': 'v=05522e67adb8b30c',
        'actionConf': 'v=59f0fad74c9c1db4',
        'main': 'v=fe9fa327ea8fbb72',
        'manage/index': 'v=d41d8cd98f00b204'
        // ...
    }
    // other config
});

html 文件引用的样式文件,自动添加版本号信息

<link href="asset/common/css/main.css?v=7a6f7d07c5570c28" rel="stylesheet" />

如果是将版本号输出到特定的文件里,结果会是如下:

version.js 内容:

require.config({
    'baseUrl': '',
    'urlArgs': {
        '05522e67.tpl': 'v=05522e67adb8b30c',
        'actionConf': 'v=59f0fad74c9c1db4',
        'main': 'v=fe9fa327ea8fbb72',
        'manage/index': 'v=d41d8cd98f00b204'
        // ...
    }
});

对于引用的版本号文件,自动添加md5值作为版本号:

<script src="src/version.js?v=832b5c8b70bfebe5"></script>

附加功能

var Versioning = require('edp-build-versioning');
var edpBuildHelper = Versioning.helper;

// 可以通过 `Versioning` 提供的 `helper` 工具自动其他页面引用的样式文件
// 这样可以无需每次新增页面都需要添加要处理的样式文件
var lessFiles = edpBuildHelper.extractLinkStyleFileSync({
    scanDir: './templates',
    preprocess: function (path) {
        return path.replace(/\{\$site_host\}\//, '');
    }
});

var lessCompiler = new LessCompiler({
    files: lessFiles
});

// 通过 `Versioning` 提供的 `helper` 工具可以自动提取页面入口模块作为要打包合并的模块
var moduleCompiler = new ModuleCompiler({
    files: [
        '*.js',
        '!dep/feedback/feedback.js'
    ],
    getCombineConfig: function () {
        var entryModuleIds = edpBuildHelper.extractPageEntryModules({
            scanDir: './templates',
            filter: function (id) {
                // 滤掉不合并的模块
                return !/(^echarts|^common)\W*/.test(id);
            }
        });

        var combineConf = {};
        entryModuleIds.forEach(function (id) {
            combineConf[id] = 1;
        });

        return combineConf;
    }
});
0.1.11

8 years ago

0.1.10

9 years ago

0.1.9

9 years ago

0.1.8

9 years ago

0.1.7

9 years ago

0.1.6

10 years ago

0.1.5

10 years ago

0.1.4

10 years ago

0.1.3

10 years ago

0.1.2

10 years ago

0.1.1

10 years ago