首页 家居生活 家电资讯 软件资讯 化工资讯 五金资讯 范文论文 动漫资讯 心情说说 房产资讯 新能源 健康资讯 女性话题 医疗资讯 娱乐资讯 趣闻趣事 故事会
您当前的位置 :软件资讯 >  正文
优化RequireJS项目的相 关技巧总结
http://yangdaipin.com.cn2020-10-17

  本文将演示如何合并与压缩一个基于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),从现在起我将把这个目录引用为

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

  index.html引用脚本文件的代码

  

1 2 3 4 <script data-main="js/main" src="http://dntxw.com/skin/default/image/lazy.gif" class="lazy" original="http://dntxw.com/skin/default/image/nopic.gif" <![if IE]> <script src="http://dntxw.com/skin/default/image/lazy.gif" class="lazy" original="http://dntxw.com/skin/default/image/nopic.gif" <![endif]>

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

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

  我们将用RequireJS Optimizer(RequireJS优化器)来优化这个项目。根据已下载的说明文件,找到r.js并将其复制到
智能网页客服机器人价格 http://www.easyliao.com/

相关报道
优化RequireJS项目的相 关技巧总结
168金服如何进行投资_168金服有哪些还款方式
bm是什么意思 bm文件怎么打开
win10摄像头无法打开怎么办 win10摄像头不能用解决方法
赛迪报告显示:360手机卫士用户量超1.2亿
win10系统SSD固态硬盘开启AHCI后系 统卡顿/假死/蓝屏死机如何解
iphone,ipad变菲林底片扫瞄器视频教程
Apple Watch OS 2新功能 Apple Watch OS 2更新了什么
dnf2014劳动节高级礼包多少钱 2014dnf五一劳动节礼包有什么
itunes无法将数值apsdaemon写入键原因及解决方法
 
 
 热门新闻
· 优化RequireJS项目的相 关技巧总结
· dnf2014劳动节高级礼包多少钱 2014dnf五一劳动节礼包有什么
· itunes无法将数值apsdaemon写入键原因及解决方法
· 快手玫瑰花特效怎么拍?快手玫瑰花特效拍摄教程
· 百度回收站绿色服务联盟成立 提供电子废物回收服务
· 好好贷怎么样?好好贷靠谱吗?
· Windows Server 2008 R2 下配置证书服务器和HTTPS的图文教程
· FLASH鼠标点击显示打散动画
· CentOS修改IP地址操作步骤教程
· 坚果手机特别版是什么?特别版坚果手机配置造型
 推荐
· bm是什么意思 bm文件怎么打开
· win10摄像头无法打开怎么办 win10摄像头不能用解决方法
· 赛迪报告显示:360手机卫士用户量超1.2亿
· win10系统SSD固态硬盘开启AHCI后系 统卡顿/假死/蓝屏死机如何解
· iphone,ipad变菲林底片扫瞄器视频教程
· Apple Watch OS 2新功能 Apple Watch OS 2更新了什么
· iPhone 6售后服务差评:换屏成功率低
· 绚烂多彩:芯型1+1盈通雪狐865pe主板登场
· 阿里云邮箱如何搜索某一发件人的所有邮件
· iOS开发:Unity_3D 使用C#语言建立本地数据库
正宏G网