[转]为Magento提速再做一点小努力之移除不需要的JS

2,205次阅读
没有评论

共计 1772 个字符,预计需要花费 5 分钟才能阅读完成。

Magento的速度一直是个让人头疼的问题,加大硬件投入是效果最明显的,当然程序层面还是要努力的优化。常见的优化方式就不多说了,不外乎开启gzip,关闭不需要的模块,装php加速器等等,网上有一篇已经被转载了无数遍的文章专门有讲到。今天讲到的是一些小手段,有多少效果还未知,不过至少不会变慢。

有些人可能会注意到,新安装的Magento项目,本身页面就载入了很多外置JS,这里以1.4.1.0为例,通过Firebug可以看到,在没有修改任何文件和添加任何数据的情况下,Magento首页就要载入13个外置JS,总计300K出头(不算Gzip压缩),可是Magento真的需要那么多JS吗,就算需要,那退一步讲,首页能用到的JS能有几个。首页的载入速度是网站速度中很重要的一环,一方面是因为这是用户看到的第一个页面,另一方面访问其他页面时,浏览器可以大量使用已经从首页读来的数据缓存,而不必重新完全载入,所以会比访问首页快得多。

[转]为Magento提速再做一点小努力之移除不需要的JS

所以我的方式就是想办法在首页去掉那些首页用不到的外置JS,减少请求数。经过不完全测试,针对我自己在做的项目,slider.js,dragdrop.js,builder.js和ccard.js对首页是无效的,移除后没有任何影响,同时据估计,如果首页用不到表单验证,validation.js应该也是没有用的(这个是大头,有34KB)。我并没有测试所有的JS,而且不同的项目有不同的首页,可能需求的JS也不同,只是提供一种思路,对页面无用的JS是没必要载入的。

如何只在首页不载入某些特定的JS,这里提供一种方式。我们知道,通用的JS文件是在layout目录下的page.xml中载入的,载入的方式如下

<block type=”page/html_head” name=”head” as=”head”>
<action method=”addJs”><mce:script type=”text/javascript”><!–
prototype/prototype.js
// –></mce:script></action>
<action method=”addJs” ifconfig=”dev/js/deprecation”><mce:script type=”text/javascript”><!–
prototype/deprecation.js
// –></mce:script></action>
<action method=”addJs”><mce:script type=”text/javascript”><!–
lib/ccard.js
// –></mce:script></action>
…………………………………………………………………………

在head这个block中用<action method=”addJs”>的方式载入外部的JS文件,相对应的,我们同样可以用写xml的方式移除这些JS文件,方法如下

<reference name=”head”>
<action method=”removeItem”><type>js</type><name>scriptaculous/builder.js</name></action>
<action method=”removeItem”><type>js</type><name>scriptaculous/dragdrop.js</name></action>
…………………………………………………………………………………………

因为只是在首页移除这些JS,其他页面还是要用的,所以把这段xml写在后台首页的CMS里。点击进入后台首页的CMS,点击左边的Design,把移除JS的代码写在Layout Update XML里面,保存后就可以看到效果,首页已经不会再载入你移除掉的JS,而其它页面依然存在。

[转]为Magento提速再做一点小努力之移除不需要的JS

同样的方式除了首页其他页面也可以使用,如果有足够的耐心的话,至少内容少了,访问速度总是会有所提升,不管效果明不明显。

 

PS:类似的思路我之前发过一篇文章,因为Magento的核心库prototype.js有127KB之巨,而绝大多数人应该是不会去动核心库的代码的,所以可以把prototype.js压缩,然后替换掉原来的,类似于jquery会提供一个jquery.min.js。

正文完
 0
评论(没有评论)

空瓶子部落

文章搜索
推荐阅读
焊接工艺中容易忽略的13个问题,但SQE不能忽视!

焊接工艺中容易忽略的13个问题,但SQE不能忽视!

在焊接过程中,有许多需要注意的事项,一旦疏忽,有可能铸成大错。那么对于SQE来说,如果审核焊接工艺过程,这些要...
质量宣传标语大全(400多条)

质量宣传标语大全(400多条)

质量标语、质量口号在我们工作、生活中随处可见。有些标语高端大气上档次,而有些标语则很奇葩。你还记得哪些标语让你...
Minitab之全因子试验

Minitab之全因子试验

试验设计基本概念 试验设计(Design of Experiments,简称DOE)是一套用于评估变量对产品或...
质量管理是什么?质量管理怎么管?

质量管理是什么?质量管理怎么管?

提到质量管理,大家都不陌生,许多企业都将其视为运营中的关键部分。然而,当深入探讨质量管理究竟管什么时,很多人却...
DFMEA 与 PFMEA预防措施的不同-以装配过程为例

DFMEA 与 PFMEA预防措施的不同-以装配过程为例

在汽车制造领域中,DFMEA(设计失效模式与影响分析)和 PFMEA(过程失效模式与影响分析)都扮演着极为重要...
最新文章
群晖 Let’s Encrypt 泛域名证书自动更新

群晖 Let’s Encrypt 泛域名证书自动更新

目前acme协议版本更新,开始支持泛域名(wildcard),也就是说,可以申请一个类似*.domain.co...
可以卸载TV Box 了,这款支持「绅士模式」的影视神器你值得拥有

可以卸载TV Box 了,这款支持「绅士模式」的影视神器你值得拥有

还在为找优秀片源难、广告多、平台会员太贵而烦恼?今天给大家挖到一款真正的影视宝藏工具——小猫影视! 作为开源免...
【收藏】一次性解决TV点播/直播自由

【收藏】一次性解决TV点播/直播自由

很多时候,资源就在面前,但是我们视而不见,因为长久的安逸,已经让人失去动手的兴趣。但是每次我需要挨个切换APP...
OpenWrt 存储空间扩容的两种方案

OpenWrt 存储空间扩容的两种方案

说明:当我们通过群晖 VMM 虚拟机安装 Open­Wrt 时,默认会分配一个 10GB 的存储空间,而实际情...
OpenWrt修改IP地址两种方法(直接命令修改跟后台修改)

OpenWrt修改IP地址两种方法(直接命令修改跟后台修改)

OpenWrt是什么?OpenWrt一般常见于无线路由器(软路由)第三方固件,它是一个高效、可靠、功能多的路由...
热门文章
提高过程能力指数(CP/CPK)的途径

提高过程能力指数(CP/CPK)的途径

编者按:过程能力指数(CP/CPK)想必各位质量人都耳熟能详、运用自如,质量工程师之家前期也共享过数篇关于过程...
SPC控制图的八种模式分析

SPC控制图的八种模式分析

SPC控制图有八种模式,即八种判断异常的检验准则,每一种检验准则代表一种异常现象,应用SPC控制图进行过程评估...
测量高手放大招:圆跳动测量技巧总结

测量高手放大招:圆跳动测量技巧总结

01. 前言 在五金机加工厂实际的测量工作中,经常碰到要求测量两个要素的圆跳动问题, 利用不同的测量辅件及夹具...
过程能力分析(CP&cpk)

过程能力分析(CP&cpk)

引入过程能力分析的目的? 在我们现有的管理过程中,我们经常会遇到有些具体指标总是不尽人意,存在许多需要改进的地...
新能源汽车 “两会”精神宣贯会

新能源汽车 “两会”精神宣贯会

此次和大家分享新能源汽车相关政策: [embeddoc url=”https://www.ctro...
最新评论
多乐士 多乐士 通过摸索发现ssh拉取会报错,直接网页访问下载会报404错误,不知道原因;但是可以通过群晖CM注册表访问下载,其方法如下: Container Manager-注册表-设置-新增-注册表名称随便写,注册表URL填你的加速地址,勾选信任的SSL自我签署证书,登录信息不填-应用-使用你的地址,这是注册表会显示了,在搜索栏中输入映像名称,搜索结果在每一页的最后一个,你需要划到最后一个进行下载,实测可正常下载安装。 以上供网友参考。
多乐士 多乐士 还有一个比较简单的方法,只是需要一些外部工具。 1、讲损毁硬盘取出,装入外部移动硬盘 2、打开Diskgenius,定位到硬盘 3、格式化系统分区 4、重新插入硬盘 5、存储池->修复存储池即可
多乐士 多乐士 写的不错的文章
辞了老衲 辞了老衲 这个确实有帮助。
渋驀 渋驀 当然任何时候都可以用curl命令和crontab来实现动态更新DDNS的ip地址: 1、安装crontab之后为root用户创建文件/var/spool/cron/root 2、创建并配置ddnsupdate.sh,放到/usr/bin/文件下,文件内容(以he.net为例): Autodetect my IPv4/IPv6 address: IPV4:curl -4 "http://dyn.example.com:password@dyn.dns.he.net/nic/update?hostname=dyn.example.com" IPV6:curl -6 "http://dyn.example.com:password@dyn.dns.he.net/nic/update?hostname=dyn.example.com" 3、添加执行权限chomod +x /usr/bin/ddnsupdate.sh 4、编辑root用户的crontab:*/10 * * * * /usr/binddnsupdate.sh,每10分钟执行一次。好了,可以享受你的DDNS了
21410 21410 请问下载链接在那里?
madkylin madkylin 不错,不错,谢谢分享了,好东西啊 :lol:
feilung feilung 求方法
zengsuyi zengsuyi 应该挺不错的
zise zise 看看是怎么操作的。。 :oops: