js报TypeError $(...) is null错误,jquery失效的原因及解决办法
最近在工作中发现个问题,原本好好的网页,写了一些自己的jquery代 码之后,竟然总是不起作用,无论写的多么简单,都不起作用,似乎jquery失效了一般,在火狐下调试看了下,页面报TypeError: $(...) is null $("#c1").change(function(){…… 这种错误,找了半天原因最后发现竟是页面中加载的一个插件给捣的鬼,是它将jquery的$方法给覆盖了。对于这个问题,现在分享两种解决方法。
(1)删冲突插件,jquery作为基础库,当然是没有理由被删了。这个方法最直接了。
jQuery.noConflict();
//将变量$的控制权让渡给给其他插件或库
jQuery(
function
(){
//不在直接使用$,而是使用jQuery
jQuery(
"p"
).click(
function
(){
alert( jQuery(
this
).text() );
});
});
(2)如果你感觉jquery写起来比较累,还可以这么写:
将jquery的$方法改名,具体改名方法如下:
var
myJ=jQuery.noConflict();
//自定义一个别名
myJ
(
function
(){
//使用jQuery
<code class="plain"> <code>myJ
("p"
).click(
function
(){
alert(
myJ
.text() );
});
});
|
|
<br> |