当前位置: 代码迷 >> Web前端 >> twitter下发现了<jQuery Performance Rules>这篇文章
  详细解决方案

twitter下发现了<jQuery Performance Rules>这篇文章

热度:647   发布时间:2012-09-12 09:21:30.0
twitter上发现了<jQuery Performance Rules>这篇文章,
现在jquery应用的越来越多, 有些同学在享受爽快淋漓coding时就将性能问题忽略了,  比如我.jquery虽在诸多的js类库中性能表现还算优秀, 但毕竟不是在用原生的javascript开发, 性能问题还是需要引起重视的. 在twitter上发现了<jQuery Performance Rules>这篇文章, 简单的摘译了一下:
总是从ID选择器开始继承
在class前使用tag
将jquery对象缓存起来
掌握强大的链式操作
使用子查询
对直接的DOM操作进行限制
冒泡
消除无效查询
推迟到 $(window).load
压缩js
全面掌握jquery库
1,总是从ID选择器开始继承
  在jQuery中最快的选择器是ID选择器,因为它直接来自于JavaScript的getElementById()方法。
  例如有一段HTML代码:
<div id=”content”>
<form method=”post” action=”#”>
<h2>交通信号灯</h2>
<ul id=”traffic_light”>
<li><input type=”radio” class=”on” name=”light” value=”red” /> 红色</li>
<li><input type=”radio” class=”off” name=”light” value=”yellow” /> 黄色</li>
<li><input type=”radio” class=”off” name=”light” value=”green” /> 绿色</li>
</ul>
<input class=”button” id=”traffic_button” type=”submit” value=”Go” />
</form>
</div>
  如果采用下面的选择器,那么效率是低效的。
var traffic_button = $(”#content .button”);
因为button已经有ID了,我们可以直接使用ID选择器。如下所示:
var traffic_button = $(”#traffic_button”);

  当然 这只是对于单一的元素来讲。如果你需要选择多个元素,这必然会涉及到 DOM遍历和循环,
为了提高性能,建议从最近的ID开始继承。
如下所示:
var traffic_lights = $(”#traffic_light input”);

2,在class前使用tag(标签名)
  在jQuery中第二快的选择器是tag(标签)选择器( 比如:$(”head”) )。
跟ID选择器累时,因为它来自原生的getElementsByTagName() 方法。
继续看刚才那段HTML代码:
<div id=”content”>
<form method=”post” action=”#”>
<h2>交通信号灯</h2>
<ul id=”traffic_light”>
<li><input type=”radio” class=”on” name=”light” value=”red” /> 红色</li>
<li><input type=”radio” class=”off” name=”light” value=”yellow” /> 黄色</li>
<li><input type=”radio” class=”off” name=”light” value=”green” /> 绿色</li>
</ul>
<input class=”button” id=”traffic_button” type=”submit” value=”Go” />
</form>
</div>
  比如需要选择 红绿 单选框,
  那么可以使用一个tag name来限制(修饰)class ,如下所示:
var active_light = $(”input.on”);

  当然也可以结合 就近的ID,如下所示:
var active_light = $(”#traffic_light input.on”);

在使用tag来修饰class的时候,我们需要注意以下几点:
(1) 不要使用tag来修饰ID,如下所示:

var content = $(”div#content”);
  这样一来,选择器会先遍历所有的div元素,然后匹配#content。
(好像jQuery从1.3.1开始改变了选择器核心后,不存在这个问题了。暂时无法考证。)
(2)不要画蛇添足的使用ID来修饰ID,如下所示:

var traffic_light = $('#content #traffic_light');

注:如果使用属性选择器,也请尽量使用tag来修饰,如下所示:
$('p[row="c3221"]').html();而不是这样:$('[row="c3221"]').html();
3,将jQuery对象缓存起来
  把jQuery对象缓存起来 就是要告诉我们 要养成将jQuery对象缓存进变量的习惯。
  下面是一个jQuery新手写的一段代码:
$(”#traffic_light input.on”).bind(”click”, function(){ … });
$(”#traffic_light input.on”).css(”border”, “1px dashed yellow”);
$(”#traffic_light input.on”).css(”background-color”, “orange”);
$(”#traffic_light input.on”).fadeIn(”slow”);

  但切记不要这么做。
  我们应该先将对象缓存进一个变量然后再操作,如下所示:
var $active_light = $('#traffic_light input.on');
$active_light.bind('click', function(){ … });
$active_light.css('border', '1px dashed yellow');
$active_light.css('background-color', 'orange');
$active_light.fadeIn('slow');

记住,永远不要让相同的选择器在你的代码里出现多次.
注:(1)为了区分普通的JavaScript对象和jQuery对象,可以在变量首字母前加上 $ 符号。
(2)上面代码可以使用jQuery的链式操作加以改善。如下所示:
var $active_light = $('#traffic_light input.on');
$active_light.bind('click', function(){ … })
             .css('border', '1px dashed yellow')
             .css('background-color', 'orange')
             .fadeIn('slow');

如果你打算在其他函数中使用jQuery对象,那么你必须把它们缓存到全局环境中。
如下代码所示:
// 在全局范围定义一个对象 (例如: window对象)
window.$my = {
head : $(”head”),
traffic_light : $(”#traffic_light”),
traffic_button : $(”#traffic_button”)
};
function do_something(){
// 现在你可以引用存储的结果并操作它们
var script = document.createElement(”script”);
$my.head.append(script);
// 当你在函数内部操作是, 可以继续将查询存入全局对象中去.
$my.cool_results = $(”#some_ul li”);
$my.other_results = $(”#some_table td”);
// 将全局函数作为一个普通的jquery对象去使用.
$my.other_results.css(”border-color”, “red”);
$my.traffic_light.css(”border-color”, “green”);
}
//你也可以在其他函数中 使用它
4,对直接的DOM操作进行限制
  这里的基本思想是在内存中建立你确实想要的东西,然后更新DOM 。
这并不是一个jQuery最佳实践,但必须进行有效的JavaScript操作 。直接的DOM操作速度很慢。
  例如,你想动态的创建一组列表元素,千万不要这样做,如下所示:
var top_100_list = [...], // 假设这里是100个独一无二的字符串
$mylist = $(”#mylist”); // jQuery 选择到 <ul> 元素
for (var i=0, l=top_100_list.length; i<l; i++){
  $mylist.append(”<li>” + top_100_list[i] + “</li>”);
}
  我们应该将整套元素字符串在插入进dom中之前先全部创建好,如下所示:
var top_100_list = [...],$mylist = $(”#mylist”), top_100_li = “”; // 这个变量将用来存储我们的列表元素
for (var i=0, l=top_100_list.length; i<l; i++){
   top_100_li += “<li>” + top_100_list[i] + “</li>”;
}
$mylist.html(top_100_li);
  注:记得以前还看过一朋友写过这样的代码:
for (i = 0; i < 1000; i++) {
    var $myList = $(’#myList’);
    $myList.append(’This is list item ‘ + i);
}
  呵呵,你应该已经看出问题所在了。既然把#mylist循环获取了1000次!!!

5,冒泡
  除非在特殊情况下, 否则每一个js事件(例如:click, mouseover等.)都会冒泡到父级节点。
  当我们需要给多个元素调用同个函数时这点会很有用。
  代替这种效率很差的多元素事件监听的方法就是, 你只需向它们的父节点绑定一次。
  比如, 我们要为一个拥有很多输入框的表单绑定这样的行为: 当输入框被选中时为它添加一个class
  传统的做法是,直接选中input,然后绑定focus等,如下所示:
$(”#entryform input”).bind(”focus”, function(){
    $(this).addClass(”selected”);
}).bind(”blur”, function(){
    $(this).removeClass(”selected”);
});
  当然上面代码能帮我们完成相应的任务,但如果你要寻求更高效的方法,请使用如下代码:
$(”#entryform”).bind(”focus”, function(e){
    var $cell = $(e.target); // e.target 捕捉到触发的目标元素
    $cell.addClass(”selected”);
}).bind(”blur”, function(e){
    var $cell = $(e.target);
    $cell.removeClass(”selected”);
});
  通过在父级监听获取焦点和失去焦点的事件,对目标元素进行操作。
在上面代码中,父级元素扮演了一个调度员的角色, 它可以基于目标元素绑定事件。
  如果你发现你给很多元素绑定了同一个事件监听, 那么现在的你肯定知道哪里做错了。
  同理,在Table操作时,我们也可以使用这种方式加以改进代码:
  普通的方式:
$(’#myTable td’).click(function(){
    $(this).css(’background’, ‘red’);
});
改进方式:
$(’#myTable’).click(function(e) {
     var $clicked = $(e.target);
     $clicked.css(’background’, ‘red’);
});
  假设有100个td,在使用普通的方式的时候,你绑定了100个事件。
  在改进方式中,你只为一个元素绑定了1个事件,
  至于是100个事件的效率高,还是1个事件的效率高,相信你也能自行分辨了。

6,推迟到 $(window).load
  jQuery对于开发者来说有一个很诱人的东西, 可以把任何东西挂到$(document).ready下。
  尽管$(document).rady 确实很有用, 它可以在页面渲染时,其它元素还没下载完成就执行。
  如果你发现你的页面一直是载入中的状态,很有可能就是$(document).ready函数引起的。
  你可以通过将jQuery函数绑定到$(window).load 事件的方法来减少页面载入时的cpu使用率。
  它会在所有的html(包括<iframe>)被下载完成后执行。
$(window).load(function(){
    // 页面完全载入后才初始化的jQuery函数.
});
  一些特效的功能,例如拖放, 视觉特效和动画, 预载入隐藏图像等等,都是适合这种技术的场合。
7,压缩JavaScript
  压缩和最小化你的JavaScript文件。
  在线压缩地址: http://dean.edwards.name/packer/
  压缩之前,请保证你的代码的规范性,否则可能失败,导致Js错误。
8,尽量使用ID代替Class。
  前面性能优化已经说过,ID选择器的速度是最快的。所以在HTML代码中,能使用ID的尽量使用ID来代替class。
  看下面的一个例子:
// 创建一个list
var $myList = $(’#myList’);
var myListItems = ‘<ul>’;
for (i = 0; i < 1000; i++) {
     myListItems += ‘<li class=”listItem’ + i + ‘”>This is a list item</li>’; //这里使用的是class
}
myListItems += ‘</ul>’;
$myList.html(myListItems);
// 选择每一个 li
for (i = 0; i < 1000; i++) {
    var selectedItem = $(’.listItem’ + i);
}
  在代码最后,选择每个li的过程中,总共用了5066毫秒,超过5秒了。
接着我们做一个对比,用ID代替class:
// 创建一个list
var $myList = $(’#myList’);
var myListItems = ‘<ul>’;
for (i = 0; i < 1000; i++) {
    myListItems += ‘<li id=”listItem’ + i + ‘”>This is a list item</li>’; //这里使用的是id
}
myListItems += ‘</ul>’;
$myList.html(myListItems);
// 选择每一个 li
for (i = 0; i < 1000; i++) {
     var selectedItem = $(’#listItem’ + i);
}
  在上段代码中,选择每个li总共只用了61毫秒,相比class的方式,将近快了100倍。

9,给选择器一个上下文
  jQuery选择器中有一个这样的选择器,它能指定上下文。
jQuery( expression, context );
  通过它,能缩小选择器在DOM中搜索的范围,达到节省时间,提高效率。
普通方式:
$(’.myDiv’)

  改进方式:
$(’.myDiv’ , $(”#listItem”) )

10,慎用 .live()方法(应该说尽量不要使用)
  这是jQuery1.3.1版本之后增加的方法,这个方法的功能就是为 新增的DOM元素 动态绑定事件。
  但对于效率来说,这个方法比较占用资源。所以请尽量不要使用它。
  例如有这么一段代码:
<script type=”text/javascript” >
$(function(){
$(”p”).click(function(){
     alert( $(this).text() );
});
$(”button”).click(function(){
    $(”<p>this is second p</p>”).appendTo(”body”);
});
}) </script>
<body>
<p>this is first p</p> <button>add</button>
</body>
  运行后,你会发现 新增 的 p元素,并没用被绑定click事件。
  你可以改成.live(”click”)方式解决此问题,代码如下:
$(function(){
$(”p”).live(”click”,function(){ //改成live方式
     alert( $(this).text() );
});
$(”button”).click(function(){ $(”<p>this is second p</p>”).appendTo(”body”); });})
  但我并不建议大家这么做,我想用另一种方式去解决这个问题,代码如下:
$(function(){
$(”p”).click(function(){
    alert( $(this).text() );
});
$(”button”).click(function(){
    $(”<p>this is second p</p>”).click(function(){  //为新增的元素重新绑定一次
            alert( $(this).text() );
    }).appendTo(”body”);
});
})
  虽然我把绑定事件重新写了一次,代码多了点,但这种方式的效率明显高于live()方式,
  特别是在频繁的DOM操作中,这点非常明显。

11,子选择器和后代选择器
  后代选择器经常用到,比如:$(”#list  p”);
  后代选择器获取的是元素内部所有元素。
  而有时候实际只要获取 子元素,那么就不应该使用后代选择器。
  应该使用子选择器,代码如下:
$(”#list > p”);

12,使用data()方法存储临时变量
  下面是一段非常简单的代码,
$(function(){
    var flag = false;
    $(”button”).click(function(){
        if(flag){
            $(”p”).text(”true”);
            flag=false;
        }else{
            $(”p”).text(”false”);
            flag=true;
        }
    });
})
  改用data()方式后,代码如下:
$(function(){
    $(”button”).click(function(){
        if( $(”p”).data(”flag”) ){
            $(”p”).text(”true”);
            $(”p”).data(”flag”,false);
        }else{
             $(”p”).text(”false”);
             $(”p”).data(”flag”,true);
        }
    });
})
一、简介

1.1、概述
  随着WEB2.0及 ajax思想在互联网上的快速发展传播,陆续出现了一些优秀的Js框架,其中比较著名的有Prototype、YUI、jQuery、mootools、 Bindows以及国内的JSVM框架等,通过将这些JS框架应用到我们的项目中能够使程序员从设计和书写繁杂的JS应用中解脱出来,将关注点转向功能需 求而非实现细节上,从而提高项目的开发速度。
  jQuery是继prototype 之后的又一个优秀的Javascript框架。它是由 John Resig 于 2006 年初创建的,它有助于简化 JavaScript? 以及Ajax 编程。有人使用这样的一比喻来比较prototype和jQuery:prototype就像Java,而jQuery就像ruby. 它是一个简洁快速灵活的JavaScript框架,它能让你在你的网页上简单的操作文档、处理事件、实现特效并为Web页面添加Ajax交互。

它具有如下一些特点:
代码简练、语义易懂、学习快速、文档丰富。
jQuery是一个轻量级的脚本,其代码非常小巧,最新版的JavaScript包只有20K左右。
jQuery支持CSS1-CSS3,以及基本的xPath。
jQuery是跨浏览器的,它支持的浏览器包括IE 6.0+, FF 1.5+, Safari 2.0+, Opera 9.0+。
可以很容易的为jQuery扩展其他功能。
能将JS代码和HTML代码完全分离,便于代码和维护和修改。
插件丰富,除了jQuery本身带有的一些特效外,可以通过插件实现更多功能,如表单验证、tab导航、拖放效果、表格排序、DataGrid,树形菜单、图像特效以及ajax上传等。
  jQuery的设计会改变你写JavaScript代码的方式,降低你学习使用JS操作网页的复杂度,提高网页JS开发效率,无论对于js初学者还是资深专家,jQuery都将是您的首选。
jQuery适合于设计师、开发者以及那些还好者,同样适合用于商业开发,可以说jQuery适合任何JavaScript应用的地方,可用于不同的Web应用程序中。
官方站点:http://jquery.com/   中文站点:http://jquery.org.cn/

1.2、目的
  通过学习本文档,能够对jQuery有一个简单的认识了解,清楚JQuery与其他JS框架的不同,掌握jQuery的常用语法、使用技巧及注意事项。

二、使用方法
  在需要使用JQuery的页面中引入JQuery的js文件即可。
例如:<script type="text/javascript" src="js/jquery.js" mce_src="js/jquery.js"></script>
  引入之后便可在页面的任意地方使用jQuery提供的语法。

三、学习教程及参考资料
  请参照《jQuery中文API手册》和http://jquery.org.cn/visual/cn/index.xml
推荐两篇不错的jquery教程:《jQuery的起点教程》和《使用 jQuery 简化 Ajax 开发》


四、语法总结和注意事项

1、关于页面元素的引用
  通过jquery的$()引用元素包括通过id、class、元素名以及元素的层级关系及dom或者xpath条件等方法,且返回的对象为jquery对象(集合对象),不能直接调用dom定义的方法。

2、jQuery对象与dom对象的转换
  只有jquery对象才能使用jquery定义的方法。注意dom对象和jquery对象是有区别的,调用方法时要注意操作的是dom对象还是jquery对象。
普通的dom对象一般可以通过$()转换成jquery对象。
如:$(document.getElementById("msg"))则为jquery对象,可以使用jquery的方法。
  由于jquery对象本身是一个集合。所以如果jquery对象要转换为dom对象则必须取出其中的某一项,一般可通过索引取出。
  如:$("#msg")[0],$("div").eq(1)[0],$("div").get()[1],$("td")[5]这些都是dom对象,可以使用dom中的方法,但不能再使用Jquery的方法。
以下几种写法都是正确的:
$("#msg").html();
$("#msg")[0].innerHTML;
$("#msg").eq(0)[0].innerHTML;
$("#msg").get(0).innerHTML;

3、如何获取jQuery集合的某一项
  对于获取的元素集合,获取其中的某一项(通过索引指定)可以使用eq或get(n)方法或者索引号获取,要注意,eq返回的是jquery对象,而get(n)和索引返回的是dom元素对象。对于jquery对象只能使用jquery的方法,而dom对象只能使用dom的方法,如要获取第三个<div>元素的内容。有如下两种方法:
$("div").eq(2).html();     //调用jquery对象的方法
$("div").get(2).innerHTML;   //调用dom的方法属性

4、同一函数实现set和get
  Jquery中的很多方法都是如此,主要包括如下几个:
$("#msg").html();     //返回id为msg的元素节点的html内容。
$("#msg").html("<b>new content</b>"); 
//将“<b>new content</b>” 作为html串写入id为msg的元素节点内容中,页面显示粗体的new content

$("#msg").text();     //返回id为msg的元素节点的文本内容。
$("#msg").text("<b>new content</b>"); 
//将“<b>new content</b>” 作为普通文本串写入id为msg的元素节点内容中,页面显示<b>new content</b>

$("#msg").height();     //返回id为msg的元素的高度
$("#msg").height("300");   //将id为msg的元素的高度设为300
$("#msg").width();     //返回id为msg的元素的宽度
$("#msg").width("300");   //将id为msg的元素的宽度设为300

$("input").val(");   //返回表单输入框的value值
$("input").val("test");   //将表单输入框的value值设为test

$("#msg").click();   //触发id为msg的元素的单击事件
$("#msg").click(fn);   //为id为msg的元素单击事件添加函数
同样blur,focus,select,submit事件都可以有着两种调用方法

5、集合处理功能
  对于jquery返回的集合内容无需我们自己循环遍历并对每个对象分别做处理,jquery已经为我们提供的很方便的方法进行集合的处理。
包括两种形式:
$("p").each(function(i){this.style.color=['#f00','#0f0','#00f'][i]}) 
//为索引分别为0,1,2的p元素分别设定不同的字体颜色。

$("tr").each(function(i){this.style.backgroundColor=['#ccc','#fff'][i%2]}) 
//实现表格的隔行换色效果

$("p").click(function(){alert($(this).html())})   
//为每个p元素增加了click事件,单击某个p元素则弹出其内容

6、扩展我们需要的功能
$.extend({
   min: function(a, b){return a < b?a:b; },
   max: function(a, b){return a > b?a:b; }
});   //为jquery扩展了min,max两个方法
使用扩展的方法(通过“$.方法名”调用):
alert("a=10,b=20,max="+$.max(10,20)+",min="+$.min(10,20));

7、支持方法的连写
  所谓连写,即可以对一个jquery对象连续调用各种不同的方法。
  例如:
$("p").click(function(){alert($(this).html())})
.mouseover(function(){alert('mouse over event')})
.each(function(i){this.style.color=['#f00','#0f0','#00f'][i]});

8、操作元素的样式
  主要包括以下几种方式:
$("#msg").css("background");     //返回元素的背景颜色
$("#msg").css("background","#ccc")   //设定元素背景为灰色
$("#msg").height(300); $("#msg").width("200");   //设定宽高
$("#msg").css({ color: "red", background: "blue" });//以名值对的形式设定样式
$("#msg").addClass("select");   //为元素增加名称为select的class
$("#msg").removeClass("select");   //删除元素名称为select的class
$("#msg").toggleClass("select");   //如果存在(不存在)就删除(添加)名称为select的class

9、完善的事件处理功能
  Jquery已经为我们提供了各种事件处理方法,我们无需在html元素上直接写事件,而可以直接为通过jquery获取的对象添加事件。
如:
$("#msg").click(function(){alert("good")})   //为元素添加了单击事件
$("p").click(function(i){this.style.color=['#f00','#0f0','#00f'][i]})
//为三个不同的p元素单击事件分别设定不同的处理
jQuery中几个自定义的事件:
(1)hover(fn1,fn2):一个模仿悬停事件(鼠标移动到一个对象上面及移出这个对象)的方法。当鼠标移动到一个匹配的元素上面时,会触发指定的第一个函数。当鼠标移出这个元素时,会触发指定的第二个函数。
//当鼠标放在表格的某行上时将class置为over,离开时置为out。
$("tr").hover(function(){
$(this).addClass("over");
},
   function(){
   $(this).addClass("out");
});
(2)ready(fn):当DOM载入就绪可以查询及操纵时绑定一个要执行的函数。
$(document).ready(function(){alert("Load Success")})
//页面加载完毕提示“Load Success”,相当于onload事件。与$(fn)等价
(3)toggle(evenFn,oddFn): 每次点击时切换要调用的函数。如果点击了一个匹配的元素,则触发指定的第一个函数,当再次点击同一元素时,则触发指定的第二个函数。随后的每次点击都重复对这两个函数的轮番调用。
   //每次点击时轮换添加和删除名为selected的class。
   $("p").toggle(function(){
     $(this).addClass("selected");  
   },function(){
     $(this).removeClass("selected");
   });
(4)trigger(eventtype): 在每一个匹配的元素上触发某类事件。
例如:
   $("p").trigger("click");     //触发所有p元素的click事件
(5)bind(eventtype,fn),unbind(eventtype): 事件的绑定与反绑定
从每一个匹配的元素中(添加)删除绑定的事件。
例如:
$("p").bind("click", function(){alert($(this).text());});   //为每个p元素添加单击事件
$("p").unbind();   //删除所有p元素上的所有事件
$("p").unbind("click")   //删除所有p元素上的单击事件

10、几个实用特效功能
  其中toggle()和slidetoggle()方法提供了状态切换功能。
  如toggle()方法包括了hide()和show()方法。
  slideToggle()方法包括了slideDown()和slideUp方法。

11、几个有用的jQuery方法
$.browser.浏览器类型:检测浏览器类型。有效参数:safari, opera, msie, mozilla。如检测是否ie:$.browser.isie,是ie浏览器则返回true。
$.each(obj, fn):通用的迭代函数。可用于近似地迭代对象和数组(代替循环)。

$.each( [0,1,2], function(i, n){ alert( "Item #" + i + ": " + n ); });
等价于:
var tempArr=[0,1,2];
for(var i=0;i<tempArr.length;i++){
   alert("Item #"+i+": "+tempArr[i]);
}
也可以处理json数据,如
$.each( { name: "John", lang: "JS" }, function(i, n){ alert( "Name: " + i + ", Value: " + n ); });
结果为:
Name:name, Value:John
Name:lang, Value:JS
$.extend(target,prop1,propN):用一个或多个其他对象来扩展一个对象,返回这个被扩展的对象。这是jquery实现的继承方式。
如:
$.extend(settings, options); 
//合并settings和options,并将合并结果返回settings中,相当于options继承setting并将继承结果保存在setting中。
var settings = $.extend({}, defaults, options);
//合并defaults和options,并将合并结果返回到setting中而不覆盖default内容。
可以有多个参数(合并多项并返回)
$.map(array, fn):数组映射。把一个数组中的项目(处理转换后)保存到到另一个新数组中,并返回生成的新数组。
如:
var tempArr=$.map( [0,1,2], function(i){ return i + 4; });
tempArr内容为:[4,5,6]
var tempArr=$.map( [0,1,2], function(i){ return i > 0 ? i + 1 : null; });
tempArr内容为:[2,3]
$.merge(arr1,arr2):合并两个数组并删除其中重复的项目。
如:$.merge( [0,1,2], [2,3,4] )   //返回[0,1,2,3,4]
$.trim(str):删除字符串两端的空白字符。
如:$.trim("   hello, how are you?   ");   //返回"hello,how are you? "

12、解决自定义方法或其他类库与jQuery的冲突
  很多时候我们自己定义了$(id)方法来获取一个元素,或者其他的一些js类库如prototype也都定义了$方法,如果同时把这些内容放在一起就会引起变量方法定义冲突,Jquery对此专门提供了方法用于解决此问题。
  使用jquery中的jQuery.noConflict();方法即可把变量$的控制权让渡给第一个实现它的那个库或之前自定义的$方法。之后应用Jquery的时候只要将所有的$换成jQuery即可,如原来引用对象方法$("#msg")改为jQuery("#msg")。
如:
jQuery.noConflict();
// 开始使用jQuery
jQuery("div   p").hide();
// 使用其他库的 $()
$("content").style.display = 'none';
  相关解决方案