requireJs压缩合并路径问题

简介: 描述 随着前端开发的重要性,以及业务的复杂性,前端的模块化开发也被大众所接收,最常见的js框架requireJs,一个js文件对应一个模块,方便开发人员调试与维护,但是一个文件对应一个模块增加了http请求,降低了网站的性能。

描述

随着前端开发的重要性,以及业务的复杂性,前端的模块化开发也被大众所接收,最常见的js框架requireJs,一个js文件对应一个模块,方便开发人员调试与维护,但是一个文件对应一个模块增加了http请求,降低了网站的性能。

 

 

幸运的是requireJs提供了压缩工具r.js(点击下载),r.js需要node(Node 0.4.0 或更高版本,点击下载)环境支持,安装完node就可以在命令行里对前端代码进行优化了。

1.可以在命令行执行,如下:

node r.js -o baseUrl=. paths.jquery=some/other/jquery name=main out=main-built.js

2.也可以建一个配置文件,如build.js,代码如下:

{
    appDir: "../js",
    baseUrl: "../js",
    dir: "../dist",
    optimize: "uglify",
    optimizeCss: "standard.keepLines",
    mainConfigFile: "../js/main.js",
    removeCombined: true,
    fileExclusionRegExp: /^\./,
    modules: [
        {
            name: ""
        },
        {
            name: ''
        }
    ]
}

这时只需在命令行中输入:

node r.js -o build.js

注意:r.js和build.js放在同一个文件夹

配置参数

({
    appDir: '../client',
    baseUrl: 'js',

    /*paths:{//baseUrl
        app: 'app'
    },*/
    //该路径以当前路径为起点
    dir: '../client-build',

    // Include the main configuration file.
    //该路径以当前路径为起点
    mainConfigFile: "./js/main.js",

    //加上下面这个modules,完成的是合并操作
    //路径apppDir + baseUrl + main.js
    //模块的入口文件,会从./client/js/main.js中寻找其所有的依赖项,并把他们合并成一个js文件
    modules:[
        {
            name:'config'
        }],
    // Output file.
    //out: "./js/config.js",

    // Root application module.
    //name: "config",
    removeCombined:true,
    optimizeCss:'standard',
    // Do not wrap everything in an IIFE.
    wrap: false,

    //optimize (none/uglify/closure) 是否压缩,默认设置为optimize = uglify,
    //none (OK:经测试,该参数正解)只合并不压缩,可以压缩成一个文件,但文件里面依旧保留格式,方便调试的时候查看代码
    //uglify 只压缩不合并 (亲测,既压缩又合并)
    //closure 压缩而且合并(亲测,合并不压缩)
    //optimize:"closure",

    //合并后的文件,顶部会自动生成一堆说明性的文字,包括版权啊,等等,加了下面的参数,则不再生成
    preserveLicenseComments: false,
    //

    //下面两组的作用是 把js文件中的console.log删除
    pragmas: {  cacheBust: false },
    onBuildWrite: function (moduleName, path, contents) {
       // return contents;
         return contents.replace(/console.log(.*);/g, '');
    }
})

点击这里查看完整配置参数

常见问题

压缩合并后会出现路径错误问题,主要是因为,js代码位置变了,例如:

模块a中动态加载样式,压缩后,模块a整合到其他模块中,路径发生变化

这时需要修改js代码,动态判断路径,或者在调用模块时封装模块,通过require加载模块也能解决问题,因为r.js不会把require进来的模块压缩进去

相关文章
|
5月前
|
JSON JavaScript 数据格式
NPM 发包 js 文件并支持 ts 使用(包含 gulp 打包压缩)
NPM 发包 js 文件并支持 ts 使用(包含 gulp 打包压缩)
115 0
|
5月前
如何从多个文件夹内转移全部文件(忽略文件夹的结构)(进行复制)(再打包)
该文介绍了一个工具的使用方法,用于忽略文件夹结构并合并所有图片。首先,提供了两个下载链接:百度网盘(提取码:qwu2)和蓝奏云(提取码:2r1z)。接着,展示了文件夹内的嵌套结构,包含多层文件夹和兔兔图片。通过打开工具,选择文件批量复制功能,勾选“忽略文件夹结构”和“不存在自动创建”,然后将目标文件夹“1”添加到来源路径。点击开始复制,并在需要时选择打包和删除原文件,最终会得到一个包含所有图片的压缩包。
合并多个文件的内容到一个文件
合并多个文件的内容到一个文件
|
5月前
|
JavaScript 前端开发
Gulp 打包压缩 js 文件到指定目录详细流程(修改文件名与后缀)
Gulp 打包压缩 js 文件到指定目录详细流程(修改文件名与后缀)
39 0
|
移动开发 编解码 资源调度
分集与路径合并方式
分集与路径合并方式
175 0
分集与路径合并方式
|
JavaScript 前端开发
requireJs压缩合并路径问题
随着前端开发的重要性,以及业务的复杂性,前端的模块化开发也被大众所接收,最常见的js框架requireJs,一个js文件对应一个模块,方便开发人员调试与维护,但是一个文件对应一个模块增加了http请求,降低了网站的性能。幸运的是requireJs提供了压缩工具r.js(点击下载),r.js需要node(Node 0.4.0 或更高版本,点击下载)环境支持,安装完node就可以在命令行里对前端代码进行优化了。
requireJs压缩合并路径问题
|
存储 自然语言处理 算法
4.1 打包和压缩的概念和区别
在讲解具体的归档命令和压缩命令之前,先来了解一下归档和压缩所各自代表的含义。
229 0
4.1 打包和压缩的概念和区别
|
监控 算法 Cloud Native
开发函数计算的正确姿势——使用 brotli 压缩大文件
函数计算对上传的 zip 代码包尺寸限制为 50M。某些场景中代码包中会超过这一限制,比如未经裁剪的 serverless-chrome,类似的还有 libreoffice ,此外常见的还有机器学习训练的模型文件。本文会比较几种常见的解决大文件的方案,并重点介绍借助 brotli 提高压缩比的方法。
开发函数计算的正确姿势——使用 brotli 压缩大文件
|
JavaScript
js实现给定图片路径自动下载
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/gisdoer/article/details/80434130 js实现图片自动下载 http://www.
1774 0