jRaiser与jQuery的冲突问题
作者:heero 来源:heero博客 发布时间:2010-07-27 12:36:00
最近有网友在留言板里问到jRaiser和jQuery的冲突问题,特此写一篇文章进行解释。
冲突的根源
众所周知,jQuery是通过一个全局变量$来引用的,而jRaiser加载时也占用了$。因而冲突的根源就是全局变量$。说得明白点:当jQuery和jRaiser共存的时候,$究竟是谁?
分析jQuery和jRaiser的源代码可以知道,这两个库在加载的时候都会占用$变量。因此,按照覆盖的原理,谁后加载,$变量就是谁。
如何解决冲突
别名法
除了$,jQuery和jRaiser都占用了另外一个变量作为别名,这个别名就是库本身的名称。
jQuery("div"); // 使用jQuery
jRaiser("div"); // 使用jRaiser
使用别名的主要问题是输入不方便:“$”只有一个字符,而“jQuery”有六个字符。但这个问题可以通过闭包解决:
(function($) {
// 此函数内的$是jQuery
$("div");
})(jQuery);
(function($) {
// 此函数内的$是jRaiser
$("div");
})(jRaiser);
使用多库共存机制
jQuery提供了jQuery.noConflict()这样一个方法,可以把$变量恢复为jQuery加载前的值。
<script type="text/javascript" src="jRaiser-1.3.3.js"></script>
<script type="text/javascript" src="jquery-1.4.2.js"></script>
<script type="text/javascript">//<![CDATA[
jQuery.noConflict();
alert($ === jRaiser); // true
//]]></script>
jRaiser也提供了类似的方法。jRaiser.retire()可以把$变量恢复为jRaiser加载前的值;而jRaiser.resume()则恢复jRaiser对$变量的占用。
<script type="text/javascript" src="jquery-1.4.2.js"></script>
<script type="text/javascript" src="jRaiser-1.3.3.js"></script>
<script type="text/javascript">//<![CDATA[
jRaiser.retire();
alert($ === jQuery); // true
jRaiser.resume();
alert($ === jRaiser); // true
//]]></script>
猜你喜欢
- 网上有这样一道题目:一个字符串String=“adadfdfseffserfefsefseetsdg”,找出里面出现次数最多的字母和出现的次
- ALTER TABLE将表更改为当前字符集。如果在执行ALTER TABLE操作期间遇到重复键错误,原因在于新的字符集将2个键映射到了相同值
- 阅读上一章:Css布局Chapter 13 为文字指定样式我想以一章的篇幅来讨论用CSS设定文字样式的做法是个好点子.一般处理文字内容大概是
- 一般现今ASP木马常通过以下四点来操作服务器,所以我们只要将一下四处设置好就能从一 前使用IIS服务器的站长很多,特别是对于ASP网站来说,
- 交互设计就是研究人与物体之间如何互动的问题,比如按电梯时,按钮立即高亮,同时屏幕上显示电梯现在所在楼层数,这个过程就是交互设计,而电梯按钮用
- jQuery.sheet 是一个用于创建 Web 电子表格的 jQuery插件,其功能及界面风格和微软的 Excel 非常相似,使得用户不至
- 1、从外部文档中粘贴时,如果不想要其格式,只要文字,可以使用“Edit->paste as text”命令,而不要直接Ctrl+V。2
- 我们日常用CSS布局的时候,关于图片背景,大部分的人都是一个背景一张图片的,怎么说呢?这是很标准的方法,但是这种普通制作方式下要保存大量图片
- 是在客户端确认还是在服务器端确认? <SCRIPT LANGUAGE="VBSc
- Rotation滤镜可以使图片产生旋转效果,注意必须是IE5.5及IE6.0才能看到!方法如下:制作过程:一、准备图片1张。二、建立一个CS
- write2vin 的 PPT原文路宛兮写的简介:本文解释了以下问题: 1.什么是用户体验? 2.谁发明了这个术语?他想表达什么意思? 3.
- 我想大家在用Sql2005一般都是.NET2005自带的SQL Server 2005是SQL Server2005 Express版本的,
- 一、创建和管理表 1、创建表语法 create table 表名(column datatype [default expr][,colum
- 文件名字处理文件名字得看业务要求。不需要保留原始名字,则随机生成名字,拼接上白名单校验过的后缀即可。反之要谨慎处理://允许上传的后缀白名单
- 代码如下:---在仓储管理中经常会碰到的一个问题 一、关于LIFO与FIFO的简单说明 ---FIFO: First in, First o
- 家里没网络,实在无聊,玩游戏都没味道,只好玩CSS。这个东西实在没什么技术含量在里面,纯属打发时间。简单说明:一张图片放在底层,
- 原文:http://www.htmldog.com/guides/htmlintermediate/badtags/十六 有害的标签 Bad
- 也许是这样的。下面我们来推荐一个简单的分页程序,代码和说明见下(两段虚线“-----”间的代码是实现该功能的重要语句):chunfeng.a
- 提要:系统自带的mysql默认字符集不是gbk,因此给数据库的推广应用以及中文程序的开发带来极大的不便,在没完没了的GBK和UTF8的转换过
- 1、选取最适用的字段属性MySQL可以很好的支持大数据量的存取,但是一般说来,数据库中的表越小,在它上面执行的查询也就会越快。因此,在创建表