jquery $.proxy使用

 

在某些情况下,我们调用Javascript函数时候,this指针并不一定是我们所期望的那个。例如:

 1 //正常的this使用
 2 $('#myElement').click(function() {
 3
 4     // 这个this是我们所期望的,当前元素的this.
 5
 6     $(this).addClass('aNewClass');
 7
 8 });
 9
10
11 //并非所期望的this
12 $('#myElement').click(function() {
13
14     setTimeout(function() {
15
16           // 这个this指向的是settimeout函数内部,而非之前的html元素
17
18         $(this).addClass('aNewClass');
19
20     }, 1000);
21
22 });

这时候怎么办呢,通常的一种做法是这样的:

 1 $('#myElement').click(function() {
 2     var that = this;   //设置一个变量,指向这个需要的this
 3
 4     setTimeout(function() {
 5
 6           // 这个this指向的是settimeout函数内部,而非之前的html元素
 7
 8         $(that).addClass('aNewClass');
 9
10     }, 1000);
11
12 });

但是,在使用了jquery框架的情况下, 有一种更好的方式,就是使用$.proxy函数。

jQuery.proxy(),接受一个函数,然后返回一个新函数,并且这个新函数始终保持了特定的上下文(context )语境。

有两种语法:

jQuery.proxy( function, context )
/**function将要改变上下文语境的函数。
** context函数的上下文语境(`this`)会被设置成这个 object 对象。
**/

jQuery.proxy( context, name )
/**context函数的上下文语境会被设置成这个 object 对象。
**name将要改变上下文语境的函数名(这个函数必须是前一个参数 ‘context’ **对象的属性)
**/

上面的例子使用这种方式就可以修改成:

$('#myElement').click(function() {

    setTimeout($.proxy(function() {

        $(this).addClass('aNewClass');  

    }, this), 1000);

});

Jquery实现ready()的源码

 
 1 function bindReady(){
 2     if ( readyBound ) return;
 3     readyBound = true;
 4
 5     // Mozilla, Opera and webkit nightlies currently support this event
 6     if ( document.addEventListener ) {
 7         // Use the handy event callback
 8         document.addEventListener( "DOMContentLoaded", function(){
 9             document.removeEventListener( "DOMContentLoaded", arguments.callee, false );
10             jQuery.ready();
11         }, false );
12
13     // If IE event model is used
14     } else if ( document.attachEvent ) {
15         // ensure firing before onload,
16         // maybe late but safe also for iframes
17         document.attachEvent("onreadystatechange", function(){
18             if ( document.readyState === "complete" ) {
19                 document.detachEvent( "onreadystatechange", arguments.callee );
20                 jQuery.ready();
21             }
22         });
23
24         // If IE and not an iframe
25         // continually check to see if the document is ready
26         if ( document.documentElement.doScroll && typeof window.frameElement === "undefined" )
27           (function(){
28             if ( jQuery.isReady ) return;
29
30             try {
31                 // If IE is used, use the trick by Diego Perini
32                 // http://javascript.nwbox.com/IEContentLoaded/
33                 document.documentElement.doScroll("left");
34             } catch( error ) {
35                 setTimeout( arguments.callee, 0 );
36                 return;
37             }
38
39             // and execute any waiting functions
40             jQuery.ready();
41         })();
42     }
43
44     // A fallback to window.onload, that will always work
45     jQuery.event.add( window, "load", jQuery.ready );
46 }   

关键:IE or Webkit|Moz 内核判断、DOMContentLoaded事件、onreadystatechange事件、readyState==“complete”

jquery $.proxy使用 Jquery实现ready()的源码的更多相关文章

  1. Jquery实现ready()的源码

    function bindReady(){ if ( readyBound ) return; readyBound = true; // Mozilla, Opera and webkit nigh ...

  2. jQuery 2.0.3 源码分析core - 选择器

         声明:本文为原创文章,如需转载,请注明来源并保留原文链接Aaron,谢谢!      打开jQuery源码,一眼看去到处都充斥着正则表达式,jQuery框架的基础就是查询了,查询文档元素对象 ...

  3. 在网站开发中很有用的8个 jQuery 效果【附源码】

    jQuery 作为最优秀 JavaScript 库之一,改变了很多人编写 JavaScript 的方式.它简化了 HTML 文档遍历,事件处理,动画和 Ajax 交互,而且有成千上万的成熟 jQuer ...

  4. 分享一组很赞的 jQuery 特效【附源码下载】

    作为最优秀的 JavaScript 库之一,jQuery 不仅使用简单灵活,同时还有许多成熟的插件可供选择,它可以帮助你在项目中加入漂亮的效果.这篇文章挑选了8个优秀的 jQuery 实例教程,这些  ...

  5. 14款让前端开发者心动的jQuery/CSS3插件及源码

    14款让前端开发者心动的jQuery/CSS3插件及源码,一起来看看. 1.jQuery左右滚动banner代码! DEMO演示    /    源码下载 2.jQuery QQ表情插件qqFace ...

  6. 第二十五课:jQuery.event.trigger的源码解读

    本课主要来讲解jQuery.event.trigger的源码解读. trigger = function(event, data, elem, onlyHandlers){ if(elem & ...

  7. jQuery 2.0.3 源码分析Sizzle引擎解析原理

    jQuery 2.0.3 源码分析Sizzle引擎 - 解析原理 声明:本文为原创文章,如需转载,请注明来源并保留原文链接Aaron,谢谢! 先来回答博友的提问: 如何解析 div > p + ...

  8. 基于jQuery经典扫雷游戏源码

    分享一款基于jQuery经典扫雷游戏源码.这是一款网页版扫雷小游戏特效代码下载.效果图如下: 在线预览   源码下载 实现的代码. html代码: <center> <h1>j ...

  9. jquery 1.7.2源码解析(二)构造jquery对象

    构造jquery对象 jQuery对象是一个类数组对象. 一)构造函数jQuery() 构造函数的7种用法: 1.jQuery(selector [, context ]) 传入字符串参数:检查该字符 ...

随机推荐

  1. ubuntu14 安装和使用docker

    Docker简介 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化.容器是完全使用沙箱机制,相互 ...

  2. 【前端学习笔记】2015-09-09~~~~nodejs中的require()和module.exports

    nodejs中一个js文件就可以看做是一个模块 在node环境中,可以直接var a=require('模块路径以及不带扩展名的模块名') exports---module.exports 其中nod ...

  3. bzoj 2300 [HAOI2011]防线修建 set动态维护凸包

    题目大意 动态删点,求凸包周长 分析 反过来变成动态加点 用set维护平衡树 具体是找到凸包上左右两点 拆开 就可以把左边当作顺时针求的一个凸包,右边当作逆时针求的一个凸包,像栈那样出set就好了 注 ...

  4. 10个JavaScript难点--摘抄

    1. 立即执行函数 立即执行函数,即Immediately Invoked Function Expression (IIFE),正如它的名字,就是创建函数的同时立即执行.它没有绑定任何事件,也无需等 ...

  5. luogu 1004 方格取数 dp

    题目链接 题意 设有N*N的方格图(N<=9),我们将其中的某些方格中填入正整数,而其他的方格中则放入数字0.如下图所示: A 0 0 0 0 0 0 0 0 0 0 13 0 0 6 0 0 ...

  6. ajax请求Url加参数的使用方法

    var cId = $(this).data('claim-id');var adoptUrl = "<?php echo $this->createUrl('claim/app ...

  7. 正确使用‘trap指令’实现Docker优雅退出

    一般应用(比如mariadb)都会有一个退出命令,用户使用类似systemctl stop ****.service方法,停止其服务时,systemd会调用其配置文件注册的退出命令,该命令执行清理资源 ...

  8. hdu 4503(数学,概率)

    湫湫系列故事——植树节 Time Limit: 1000/500 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total ...

  9. 微信小程序 赋值问题

    通常我们在页面跳转传递过来的参数要用到页面渲染时或是请求接口回来的数据要用到页面渲染时 对page的data赋值可不能用简单的变量赋值,要用微信小微信专有的this.setData方法 Page({ ...

  10. 前端笔记之Vue(七)Vue-router&axios&Vue插件&Mock.js&cookie|session&加密

    一.Vue-router(路由) 1.1路由创建 官网:https://router.vuejs.org/zh/ 用 Vue.js + Vue Router 创建单页应用,是非常简单的.使用 Vue. ...