五种方法解决Magento中jQuery和Prototype兼容性

2,734次阅读
没有评论

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

Magento的发布版本里的JS大多是用Prototype写的,如果需要引入jQuery的话,可能有些变量会冲突,所以需要做些处理来处理jQuery和Prototype的兼容性。

第一种情况:先加载Prototype,再加载jQuery

方法一:jQuery 库和它的所有插件都是在jQuery名字空间内的,包括全局变量也是保存在jQuery 名字空间内的。

使用jQuery.noConflict();主要作用是在任何时候,只要在jQuery加载后就可以调用,将$符号的使用权返回给其它的js库,jQuery在创建它自己的名字空间时就将其它库的$保存在自己的一个变量当中。

<pre>

<html>
<head>
  <script src="prototype.js"></script>
  <script src="jquery.js"></script>
  <script type="text/javascript" >
     //各个js库之间的主要冲突在于$的冲突,这个方法是用来处理这个问题的
     jQuery.noConflict(); 
     //原本使用jQuery代码部分的$ 用jQuery替代
     jQuery(document).ready(function (){
       jQuery("div").hide();
     });
     // Use Prototype with $(...), etc.
     $('proto').hide();
  </script>
</head>
<body></body>
</html></pre>

方法二:如果你仍然想使用类似于$这样比较简短的字符,你可以将jQuery.noConflict()的返回值赋值给某个变量。这个变量就是jQuery的新缩写了,当然你可以使用$以外的任意字符串,比如:

<pre>

<html>
<head>
  <script src="prototype.js"></script>
  <script src="jquery.js"></script>
  <script type="text/javascript" >
     //$j就相当于jQuery,名称你可以自主定义
     var  $j = jQuery.noConflict(); 
     // Use jQuery via $j(...)
     $j(document).ready(function (){
       $j("div").hide();
     }); 
     // Use Prototype with $(...), etc.
     $('proto').hide();
  </script>
</head>
<body></body>
</html></pre>

方法三:如果你还是想使用$,而不想使用别的字符,也是可以的。而且通常程序员都比较喜欢这样做,因为这样做写好的代码几乎都不用替换原来的$符号。那就是利用名字空间的概念就所有的jQuery代码封装在document的ready事件名字空间范围内,如:jQuery(document).ready(这里填入jQuery代码),Magento笔记喜欢使用这种方法:

<pre>

<html>
<head>
  <script src="prototype.js"></script>
  <script src="jquery.js"></script>
  <script type="text/javascript" >
    jQuery.noConflict(); 
    // Put all your code in your document ready area
    jQuery(document).ready(function ($){
      // 这样你可以在这个范围内随意使用$而不用担心冲突
      $("div" ).hide();
    }); 
    // Use Prototype with $(...), etc.
    $('proto' ).hide();
  </script>
</head>
<body></body>
</html>
</pre>

第二种情况:先加载jQuery,再加载Prototype

按照这样的顺序加载,就不存在其它js库的$符号被jQuery占用的问题。所以对其它的js库的代码可以不作任何修改,照常使用$,而对 jQuery可以使用jQuery来替代$.如:

<pre>

<html>
<head>
  <script src="prototype.js"></script>
  <script src="jquery.js"></script>
  <script type="text/javascript" >
  // 使用 jQuery 用 jQuery(...)
  jQuery(document).ready(function (){
    jQuery("div" ).hide();
  }); 
  // 使用 Prototype 时,用 $(...),
  $('someid' ).hide();
  </script>
</head>
<body></body>
</html>
</pre>
或者你不想写jQuery这么长的字符,你可以通过另外一种方法:
<pre>
var  $j = jQuery;</pre>
来实现简短一点的$j,这可能是最好的办法了。
不过,当你只想使用jQuery来写代码时,你可以通过名字空间仍然使用$,即采用和jQuery源代码一样的方法:
<pre>
<script type="text/javascript" >
    (function($) {
    /* 在这个名字空间内,你可以随意使用$符号来引用jQuery,只不过是其它$被jQuery使用,你不能使用prototype或其它的js库
    */ }
    )(jQuery)
</script>
</pre>
正文完
 0
评论(没有评论)

空瓶子部落

文章搜索
推荐阅读
海外服务器部署SiteProxy,畅享高速稳定代理服务

海外服务器部署SiteProxy,畅享高速稳定代理服务

介绍 SiteProxy 是一个功能强大的在线代理工具,采用了最新的技术,提升了代理的稳定性和兼容性。我们致力...
如果是人为操作失误,如何回答客户的8D报告?

如果是人为操作失误,如何回答客户的8D报告?

前言:本文转自 资深质量管理人 张晓霜老师,版权归张晓霜老师所有。 转录下来,供仔细体会学习。 —...
绩效不是为了克扣工资,而是激励员工!

绩效不是为了克扣工资,而是激励员工!

绩效考核,似乎成了公司里最敏感的词汇。 员工听到“考核”两个字,下意识就想到扣钱、降级、末位淘汰;管理者提起“...
汽车悬架系统结构原理概述及分类

汽车悬架系统结构原理概述及分类

汽车行驶系统由车架、车桥、悬架及车轮总成四部分组成,它们在支撑和控制车辆的行驶中发挥着重要作用。前、后车轮分别...
混动市场技术百家争鸣,谁是演技派,谁是实力派?

混动市场技术百家争鸣,谁是演技派,谁是实力派?

根据乘用车燃料消耗量第四阶段标准,汽车企业平均燃料消耗量到2020年要实现5.0L/100km的平均油耗目标。...
最新文章
Free TV:全球免费电视频道 M3U 播放列表,狂揽数万 Star

Free TV:全球免费电视频道 M3U 播放列表,狂揽数万 Star

https://github.com/Free-TV/IPTV 项目简介 Free TV 是一个精心维护的开源...
群晖 Let’s Encrypt 泛域名证书自动更新

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

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

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

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

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

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

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

说明:当我们通过群晖 VMM 虚拟机安装 Open­Wrt 时,默认会分配一个 10GB 的存储空间,而实际情...
热门文章
提高过程能力指数(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: