如何修改jquery默认的$
jquery默认访问dom用的是$,可是我的js程序已经占用了$,所以jquery就跟我的程序有冲突。如何修改这个默认的$啊?我看有的程序用jQuery代替$,不知道怎么...
jquery默认访问dom用的是$,可是我的js程序已经占用了$,所以jquery就跟我的程序有冲突。如何修改这个默认的$啊?我看有的程序用jQuery代替$,不知道怎么实现的。
lilei51612,你没看清楚?我就是不想让他用$,因为$这个符号我已经用了,跟我的程序有冲突了,怎么修改jquery默认的$ 展开
lilei51612,你没看清楚?我就是不想让他用$,因为$这个符号我已经用了,跟我的程序有冲突了,怎么修改jquery默认的$ 展开
6个回答
展开全部
一.使用JQuery.noConflict()
该方法的作用就是让Jquery放弃对$的所有权,将$的控制权交还给prototype.js,因为jquery.js是后引入的,所以最后拥有$控制权的是jquery。它的返回值是JQuery。当在代码中调用了该 方法以后,我们就不可以使用$来调用jquery的方法了,此时$就代表在prototype.js库中定义的$了。如下:
JQuery.noConflict();
//此处不可以再写成$('#msg').hide(),此时的$代表prototype.js中定义的$符号。
JQuey('#msg').hide();
自此以后$就代表prototype.js中定义的$,jquery.js中的$无法再使用,只能使用jquery.js中$的全称JQuery了。
二.自定义JQuery的别名
如果觉得第一种方法中使用了JQuery.noConflict()方法以后,只能使用JQuery全称比较麻烦的话,我们还可以为JQuery重定义别名。如下:
var $j=JQuery.noConflict();
$j('#msg').hide();//此处$j就代表JQuery
自此以后$就代表prototype.js中定义的$,jquey.js中的$无法再使用,只能使用$j来作为jquey.js中JQuery的别名了。
三.使用语句块,在语句块中仍然使用jquery.js中定义的$,如下:
JQuery.noConflict();
JQuery(document).ready(function($){
$('#msg').hide();//此时在整个ready事件的方法中使用的$都是jquery.js中定义的$.
});
或者使用如下语句块:
(function($){
.....
$('#msg').hide();//此时在这个语句块中使用的都是jquery.js中定义的$.
})(JQuery)
该方法的作用就是让Jquery放弃对$的所有权,将$的控制权交还给prototype.js,因为jquery.js是后引入的,所以最后拥有$控制权的是jquery。它的返回值是JQuery。当在代码中调用了该 方法以后,我们就不可以使用$来调用jquery的方法了,此时$就代表在prototype.js库中定义的$了。如下:
JQuery.noConflict();
//此处不可以再写成$('#msg').hide(),此时的$代表prototype.js中定义的$符号。
JQuey('#msg').hide();
自此以后$就代表prototype.js中定义的$,jquery.js中的$无法再使用,只能使用jquery.js中$的全称JQuery了。
二.自定义JQuery的别名
如果觉得第一种方法中使用了JQuery.noConflict()方法以后,只能使用JQuery全称比较麻烦的话,我们还可以为JQuery重定义别名。如下:
var $j=JQuery.noConflict();
$j('#msg').hide();//此处$j就代表JQuery
自此以后$就代表prototype.js中定义的$,jquey.js中的$无法再使用,只能使用$j来作为jquey.js中JQuery的别名了。
三.使用语句块,在语句块中仍然使用jquery.js中定义的$,如下:
JQuery.noConflict();
JQuery(document).ready(function($){
$('#msg').hide();//此时在整个ready事件的方法中使用的$都是jquery.js中定义的$.
});
或者使用如下语句块:
(function($){
.....
$('#msg').hide();//此时在这个语句块中使用的都是jquery.js中定义的$.
})(JQuery)
展开全部
不用实现!$其实就是jQuery对象,简单的说他们2个是相等的(术语不专业,请见谅)!只不过$写起来更方便,所以就用$了!你可以看看api中,当你查找.post或是.get等等的时候!你在检索的地方输入.是查不到的,你要输入j,就能找到jquery.post等等的方法!而我们在使用的时候,就是$.post()!就是这样的,希望对你有帮助!
$(".a").text()=jQuery(".a").text();
不知道这个你能看懂吗?意思就是jQuery可以替换你的$符号!
$(".a").text()=jQuery(".a").text();
不知道这个你能看懂吗?意思就是jQuery可以替换你的$符号!
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
在jquery函数中把相应的$替换成jQuery就可以,不会和js定义的$变量产生冲突如:
jQuery("#documentId").addClass("classname")等价于$("#documentId").addClass("classname")
又如
jQuery(document).ready(function() {
jQuery("p").bind("click", function() {
alert($(this).html());
});
});
一般简写:
$(document).ready(function() {
$("p").bind("click", function() {
alert($(this).html());
});
});
jQuery("#documentId").addClass("classname")等价于$("#documentId").addClass("classname")
又如
jQuery(document).ready(function() {
jQuery("p").bind("click", function() {
alert($(this).html());
});
});
一般简写:
$(document).ready(function() {
$("p").bind("click", function() {
alert($(this).html());
});
});
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
jQuery中一个函数来防这种冲突的.
jQuery.noConflict();
也可以
jQuery(function(){
//在这里面使用$
});
把$用在jQuery命名空间里面就可以了.
jQuery.noConflict();
也可以
jQuery(function(){
//在这里面使用$
});
把$用在jQuery命名空间里面就可以了.
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
var $j = jQuery.noConflict();
// Use jQuery via $j(...)
$j(document).ready(function(){
$j("div").hide();
});
加上类似上面这个代码就可以了,意思大概就是把jquery的$换成$j,然后平时用$的地方都用$j来代替就可以了。
详细请参考参考资料的链接。
// Use jQuery via $j(...)
$j(document).ready(function(){
$j("div").hide();
});
加上类似上面这个代码就可以了,意思大概就是把jquery的$换成$j,然后平时用$的地方都用$j来代替就可以了。
详细请参考参考资料的链接。
参考资料: http://docs.jquery.com/Using_jQuery_with_Other_Libraries
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询