位置: 编程技术 - 正文

优化RequireJS项目的相关技巧总结(怎么优化项目)

发布时间:2024-02-27

推荐整理分享优化RequireJS项目的相关技巧总结(怎么优化项目),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:项目优化要素,怎么优化项目,优化项目计划,项目优化管理工具,项目优化管理工具,优化elm,优化项目是什么,优化项目流程,内容如对您有帮助,希望把文章链接给更多的朋友!

本文将演示如何合并与压缩一个基于RequireJS的项目。本文中将用到苦干个工具,这其中就包括Node.js。 因此,如果你手头上还没有Node.js可以点击此处下载一个。动机

关于RequireJS已经有很多文章介绍过了。这个工具可以将你的JavaScript代码轻易的分割成苦干个模块(module)并且保持你的代码模块化与易维护性。这样,你将获得一些具有互相依赖关系的JavaScript文件。仅仅需要在你的HTML文档中引用一个基于RequireJS的脚本文件,所有必须的文件都将会被自动引用到这个页面上.

但是,在生产环境中将所有的JavaScript文件分离,这是一个不好的做法。这会导致很多次请求(requests),即使这个些文件都很小,也会浪费很多时间。 可以通过合并这些脚本文件,以减少请求的次数达到节省加载时间的目的。

另一种节省加载时间的技巧是缩小这些被加载文件的大小,相对小一些的文件会传输的更快一些。这个过程叫作最小化 (minification) ,它是通过小心的改变脚本文件的代码结构并且不改变代码的形为(behavior)和功能(functionality)来实现的。例如这些:去除不必要的空格,缩短(mangling,或都压缩)变量(variables)名与函数(methods,或者叫方法)名,等等。这种合并并压缩文件的过程叫做代码优化( optimization)。这种方法除了用于优化(optimization)JavaScript文件,同样适用于CSS文件的优化。

RequireJS有两个主要方法(method): define()和require()。这两个方法基本上拥有相同的定义(declaration) 并且它们都知道如何加载的依赖关系,然后执行一个回调函数(callback function)。与require()不同的是, define()用来存储代码作为一个已命名的模块。 因此define()的回调函数需要有一个返回值作为这个模块定义。这些类似被定义的模块叫作AMD (Asynchronous Module Definition,异步模块定义)。

如果你不大熟悉RequireJS或者不太明白我写的东西 - 不要担心。下面有一个关于这些的例子。 JavaScript应用程序的优化

在本小节中我将向大家展示如何优化Addy Osmani的TodoMVC Backbone.js + RequireJS 项目。 由于TodoMVC项目在不同的框架下包含许多TodoMVC实现,我下载了1.1.0版并提取出Backbone.js + RequireJS应用程序。点击这里下载该应用程序并解压下载到的zip文件。todo-mvc的解压目录将是我们这个例子的根目录(root path),从现在起我将把这个目录引用为<root>。

查看<root>/index.html的源代码,你会发现它仅仅包含了一个script标签(另外一个是当你使用Internet Explorer时引用的):index.html引用脚本文件的代码

其实,整个项目只需要引用require.js这个脚本文件。如果你在浏览器中运行这个项目,并且在你喜欢的(擅长的)调试工具的network标签中, 你就会发现浏览器同时也加载了其它的JavaScript文件:

所有在红线边框里面的脚本文件都是由RequireJS自动加载的。

我们将用RequireJS Optimizer(RequireJS优化器)来优化这个项目。根据已下载的说明文件,找到r.js并将其复制到<root>目录。 jrburke的r.js是一个能运行基于AMD的项目的命令行工具,但更重要的是,它包含RequireJS Optimizer允许我们对脚本文件(scripts)合并与压缩。

RequireJS Optimizer有很多用处。它不仅能够优化单个JavaScript或单个CSS文件,它还可以优化整个项目或只是其中的一部分,甚至多页应用程序(multi-page application)。它还可以使用不同的缩小引擎(minification engines)或者干脆什么都不用(no minification at all),等等。本文无意于涵盖RequireJS Optimizer的所有可能性,在此仅演示它的一种用法。

正如我之前所提到的,我们将用到Node.js来运行优化器(optimizer)。用如下的命令运行它(optimizer):运行RequireJS Optimizer

优化RequireJS项目的相关技巧总结(怎么优化项目)

有两种方式可以将参数传递给optimizer。一种是在命令行上指定参数:在命令行上指定参数

另一种方式是构建一个配置文件(相对于执行文件夹)并包含指定的参数 :

build.js的内容:配置文件中的参数

我认为构建一个配置文件比在命令行中使用参数的可读性更高,因此我将采用这种方式。接下来我们就为项目创建一个<root>/build.js文件,并且包括以下的参数: <root>/build.j

弄明白RequireJS Optimizer的所有配置项并不是本文的目的所在,但我想解释(描述)一下本文中我所采用的参数:

了解RequireJS Optimizer的更多介绍以及更多高级应用,除了其网页早先提供的资料,你可以点击此处查阅所有可用配置选项的详细的信息。

既然现在已经有了构建文件(build file),那么就可以运行优化器(optimizer)了。进入<root> 目录并执行如下命令:运行优化器(optimizer) $ node r.js -o build.js一个新的文件夹会被生成:<root>/dist。重要的是要注意到,现在<root>/dist/js/main.js包含了所有已合并与压缩的具有依赖关系的文件。 此外,<root>/dist/css/base.css也被优化了。

运行优化后的项目,它看起来与未优化之前的项目完全一样。再检查一下该页面的网络传输(network traffic)信息,会发现仅有两个JavaScript文件被加载。

RequireJs Optimizer将服务器上的脚本文件从个减少到2个并且将文件的总大小从KB减少到.6KB(require.js与main.js)。

开销

显然,在优化之后,我们再也没有必要引用require.js文件了。因为已经没有被分离的脚本文件了并且所有具有依赖关系的文件也已被加载。

尽管如此,优化过程将我们所有的脚本合并生成了一个优化后的脚本文件,其中包含了很多次define() 和require()调用。 因此,为了保证应用程序能够正常运行,define()和require()必须指定并实施到应用程序的某处(即包含这些文件)。

这会导致一个众所周知的开销:我们总是会有一些代码实现define()和require()。这些代码并不是应用程序的一部分,它们的存在仅仅是为我们的基础建设考虑(infrastructure considerations)。 当我们开发一个JavaScript库(JavaScript library)时,这个问题变得尤为巨大。相比RequireJS,这些库通常都很小,因此在库中包含它会造成一笔巨大的开销。

在我写这篇文章的时候,对于这方面的开销还没有一个完整的解决方案,但是我们可以使用almond来缓解这个问题。Almond是一个极简单的AMD加载器,它实现了RequireJS接口(API)。因此,可以用来在已优化过的代码中替代RequireJS实现,我们可以在项目中包含almond。如令,我正致力于开发一个优化器(optimizer),它将能够优化RequireJS应用程序,而无需开销,但它仍然是一个新的项目(处于开发的初期阶段)因此这里没有任何关于它的展示。下载与总结

下载 未经优化的TodoMVC Backbone.js + RequireJS 项目或者查看它。 下载 优化后的TodoMVC Backbone.js + RequireJS 项目(位于dist文件夹下)或查看它。

在JavaScript应用中使用RequireJS来实现延迟加载 无论简单还是复杂的Web应用,都由一些HTML、JavaScript、CSS文件组成。通常开发者会通过JQuery、Knockout、Underscore等等这样的第三方JavaScript框架来提高开发

使用RequireJS优化JavaScript引用代码的方法 RequireJS是一个提高你的javascript代码速度和质量的有效方法,同时它还让你的代码更容易阅读和维护。在本文中,我会为你介绍RequireJS和应该如何使用它

超级给力的JavaScript的React框架入门教程 React是Facebook里一群牛X的码农折腾出的牛X的框架。实现了一个虚拟DOM,用DOM的方式将需要的组件秒加,用不着的秒删。React扮演着MVC结构中V的角色,不

标签: 怎么优化项目

本文链接地址:https://www.jiuchutong.com/biancheng/379074.html 转载请保留说明!

上一篇:javascript处理a标签超链接默认事件的方法(js的a标签)

下一篇:在JavaScript应用中使用RequireJS来实现延迟加载(javascript的相关应用)

  • 委托加工应税消费品代扣代缴
  • 营业税金及附加是什么科目
  • 零售和批发的界定
  • 工会经费和福利费怎么花
  • 投标保证金保险怎么买
  • 公司买手表可以抵扣吗
  • 为什么开发成本资本化
  • 成本费用总额占营业收入比重
  • 非居民工资薪金个人所得税计算方法
  • 现金流量表公式大全
  • 商品溢余做销售的会计分录怎么写?
  • 建筑公司运营的流程
  • 股票投资收益需要缴纳增值税吗
  • 增值税失控发票什么意思
  • 退货没有红字发票怎么办
  • 关于个人所得税纳税人的说法正确的有
  • 补提以前年度无形资产摊销税务处理
  • 已经销售但是没货怎么办
  • 增值税税率调整时间16变13
  • 坏账损失做哪个科目
  • 应收账款 转让
  • 旅行社开的发票是否都要差额征税
  • 土地城镇化怎么计算
  • 跨年度的收入如何做分录
  • 增值税专用发票的税率是多少啊
  • 发票备注栏填写要求
  • php常用的优化方式
  • 64位windows系统下安装Memcache缓存
  • 承兑开出去能收回吗
  • PHP:Memcached::get()的用法_Memcached类
  • 企业代付个人所得税计算公式
  • 财务费用属于期间汇转账户吗
  • 水资源税收费标准
  • 密歇根湖怎么读
  • 带息应收票据会计处理
  • 自产应税消费品用于在建工程要交增值税吗
  • php取值
  • 为什么我们认为北京人已经学会使用火
  • java编程入门基础教程
  • 以前年度损益调整是什么意思
  • 企业商品库存周期是多久
  • 接待客人的场合
  • 银行开出的承兑怎么兑现
  • 怎么样去掉
  • 收到返工费会计分录
  • 信用减值损失属于什么类
  • 工程施工企业收入1750万,利润怎么算
  • 纳税申报人的对象是哪些
  • 手撕定额发票可以抵扣吗
  • 企业网银代发工资明细打印
  • 餐饮行业纸巾入库流程
  • 公司五金是哪五金
  • 免抵退的定义
  • 公司缴纳社保如何转为个人缴纳
  • 补贴算报酬吗
  • 普通发票如何作废操作流程
  • 未缴纳或未足额缴纳出资的股东
  • 日记账怎么设置
  • sql server 判断数据是否存在
  • java如何连接sql
  • openbsd4.1+apache+mysql+php 环境配置
  • openssl安装教程
  • window打开注册表
  • windows中输入法的安装步骤
  • windows 高分屏
  • Mac系统中文件的唯一id
  • Win7系统如何打开摄像头
  • unity2d横版游戏源码
  • js修改值
  • http状态码一览表
  • opengl中点画圆算法
  • node.js中用什么方法处理get、post请求的参数
  • android 图片
  • 物理引擎百科
  • jquery插件库怎么导入
  • android开发和java开发区别
  • python 技巧
  • 立信金融会计学院
  • 北京地税残疾人补贴政策
  • 重庆国税官网网址
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号