网上资源汇总学习:

jquery的选择器是CSS1-3,xpath的结合物。JQuery提取了这二种查询语言最好的部分,创造出了最终的jquery表达式查询语言。

xpath是一门在xml文档里查找信息的语言,xpath可以用来在xml文档中对元素和属性进行遍历。xpath使用路径表达式来选取xml文档中的节点或节点集。节点是沿着路径(path)或者步(step)来选取的。它是w3c的一个标准。

JQuery选择器执行效率:

1、最快:id选择器和元素标签选择器

例如:$("#id"),$("form"),$("input")

理由:jQuery内部会自动调用浏览器的原生方法(比如getElementById()),所以它们的执行速度快。

2、较慢:class选择器
$(".classname"),取决于不同浏览器

firefox,safari,chrome,opera浏览器,原生方法getelementByClassName(),所以速度并不慢,但是IE5-8没有这个方法,所以

这个选择器在IE上会相当慢。

3、最慢的选择器:伪类选择器和属性选择器 $(":hidden"),$("attribute=value")

将jQuery对象缓存起来
把jQuery对象缓存起来 就是要告诉我们 要养成将jQuery对象缓存进变量的习惯。
下面是一个jQuery新手写的一段代码:

 
1
2
3
4
    $("#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");

但切记不要这么做。
我们应该先将对象缓存进一个变量然后再操作,如下所示:

1
2
3
4
5
    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的链式操作加以改善。如下所示:

 
1
2
3
4
5
    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");
}
//你也可以在其他函数中 使用它

冒泡
除非在特殊情况下, 否则每一个js事件(例如:click, mouseover等.)都会冒泡到父级节点。
当我们需要给多个元素调用同个函数时这点会很有用。
代替这种效率很差的多元素事件监听的方法就是, 你只需向它们的父节点绑定一次。
比如, 我们要为一个拥有很多输入框的表单绑定这样的行为: 当输入框被选中时为它添加一个class
传统的做法是,直接选中input,然后绑定focus等,如下所示:

 
1
2
3
4
5
    $("#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");
});

这篇文章写的很好,上面的缓存和冒泡是截取的里面的,记录一下,:

http://www.frontopen.com/1077.html

http://www.open-open.com/bbs/view/1318473226718

最新文章

  1. 自学MVC看这里——全网最全ASP.NET MVC 教程汇总
  2. request.getRequestDispather().forward()与response.sendRedirect()
  3. HTML Table导出为Excel的方法
  4. Vuex 模块化实现待办事项的状态管理
  5. WinForm 工作流设计 1
  6. ThreadLocal<T>学习总结
  7. Linux(Ubuntu)使用日记------Mysql编码(utf-8)的设置
  8. jQuery之标签操作和返回顶部、登录验证、全选反选、克隆示例
  9. scrapy爬取知乎问答
  10. Python的参数类型
  11. 转载:UML学习(二)-----类图(silent)
  12. 【宣讲】德州科技职业学院宣讲关于IT领域趋势分析
  13. ABP框架提示框
  14. 2017-11-26 编程语言试验之Antlr4+Java实现"圈2"
  15. 第三部分:Android 应用程序接口指南---第一节:应用程序组件---第一章1-1.Fragment
  16. $Gauss$消元
  17. linux内核空间和用户空间详解
  18. 服务器学习笔记之servlet
  19. wav2midi 音乐旋律提取算法 附可执行demo
  20. STM32运行FreeRTOS出现prvTaskExitError错误死机

热门文章

  1. 【二分答案】 【POJ3497】 【Northwestern Europe 2007】 Assemble 组装电脑
  2. 归并排序java
  3. CodeForces 222D - Olympiad
  4. F - The Circumference of the Circle
  5. mysql三张表关联查询
  6. Linux学习之fsck命令
  7. 踩坑学php(1)
  8. SquirrelMQ消息队列
  9. Nginx安装配置PHP(FastCGI)环境的教程
  10. jsp 2种include标签的区别