位置: 编程技术 - 正文

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

编辑:rootadmin

推荐整理分享优化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的相关应用)

  • 增值税税率改变后原项目的新增单价按哪个税率
  • 总分公司企业所得税合并申报
  • 计提企业所得税分录
  • 6个点税如何计算方法
  • CIA是指什么会计考试
  • 银联撤销交易步骤
  • 公司破产债务清偿顺序是怎样的
  • 母子公司无偿划转资产涉税
  • 利润表本期金额怎么算
  • 多交税款如何处罚
  • 小规模公司核定增收税可以公账直接打给法人吗?
  • 固定资产投资转化为gdp比例
  • 应收账款计提坏账后收回
  • 专用发票包括增值税吗
  • 企业会议费发票可否抵扣?
  • 办理出口退税需要的资料
  • 电梯安装简易征收的优点
  • 税号里的0是字母还是数字
  • 发票抬头开错跨月了怎么办?
  • 委托加工白酒的计税依据
  • 教育费附加记账
  • 土地增值税的土地成本要扣除增值税吗
  • 高新技术研发人员比例
  • 注册资金印花税税目
  • 系统自带功能
  • 年底会计结账
  • 支付手续费委托代销是什么意思
  • 代销方式是什么意思
  • 营改增后如何纳税
  • 长期借款和短期借款的区别是什么
  • eslint vue配置
  • 基于改进yolov4论文
  • 保险公司发票能在异开吗
  • 传统结算工具的不足有
  • 航天金税税控盘运行环境
  • 增值税不动产扣除项目
  • 非贸备案什么意思
  • 房子是固定资产的好处
  • 发票2种
  • 企业贷款贴息怎么做账
  • 三方转账协议各方怎么记账
  • 国税办税人员怎么解绑
  • sql server 查看
  • access里面也暗含了sql
  • 电商收服务费合法吗
  • 进项税额转出和红字冲销区别
  • 相同的商品附带不同的赠品发布
  • 现金池管理
  • 税收滞纳金什么意思
  • 结转损益结转了两次咋办
  • 施工总包能分包土方吗
  • 网吧出售
  • 工程投标保证金什么时候交
  • 广告制作需要交文化事业建设税
  • 收到投资款如何做税务登记
  • 购买500元的保险会计分录
  • 代扣代缴的增值税为什么可以抵扣
  • 超市库存明细表
  • 电脑开机显示xp后无反应
  • linux搭建socks代理
  • xp系统镜像文件怎么制作
  • linux必学的100个命令
  • win7运行慢如何解决办法
  • win7开机提示重启怎么办
  • shader开发实战
  • 提高网站性能
  • python计算两个数乘积代码
  • 猫的所有视频
  • ubuntu如何下载
  • 安卓开源好处
  • 删除的照片怎么还原
  • 专票开出去了多长时间必须打入账户
  • 电子税务局怎么删除办税员
  • 陕西宝鸡国税人才招聘
  • 税务税收预测
  • 如何做好税收工作推动税收事业创新发展
  • 实名办税人员承诺书范本
  • 佩兰诗胶原蛋白填充霜真的有效果吗
  • 2020十大经济年度人物揭晓
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设