- 浏览: 1237882 次
- 性别:
- 来自: 上海
文章分类
最新评论
-
lankk:
lankk 写道事实上,在运行String s1=new St ...
理解String 及 String.intern() 在实际中的应用 -
lankk:
事实上,在运行String s1=new String(&qu ...
理解String 及 String.intern() 在实际中的应用 -
lankk:
同意1楼的说法http://docs.oracle.com/j ...
理解String 及 String.intern() 在实际中的应用 -
raoyutao:
...
jdk 线程池 ThreadPoolExecutor -
hongdanning:
理解了。之前困惑的一些明白了。谢谢分享。
理解String 及 String.intern() 在实际中的应用
var scope = this; toolbar.add({ iconCls : 'graphOrderAdd', name : 'graphOrder_btn', handler : function(btn) { scope.opToolbarClick(btn) } });
写ext代码的时候经常这样写scope.opToolbarClick(btn) 为什么不能写this呢
下面贴一段网络上的
JavaScript 中的 this 一直是容易让人误用的,尤其对于熟悉 Java 的程序员来说,因为 JavaScript 中的 this 与 Java 中的 this 有很大不同。在一个 function 的执行过程中,如果变量的前面加上了 this 作为前缀的话,如this.myVal
,对此变量的求值就从 this 所表示的对象开始。
this 的值取决于 function 被调用的方式,一共有四种,具体如下:
- 如果一个 function 是一个对象的属性,该 funtion 被调用的时候,this 的值是这个对象。如果 function 调用的表达式包含句点(.)或是 [],this 的值是句点(.)或是 [] 之前的对象。如
myObj.func
和myObj["func"]
中,func
被调用时的 this 是myObj
。 - 如果一个 function 不是作为一个对象的属性,那么该 function 被调用的时候,this 的值是全局对象(注:window)。当一个 function 中包含内部 function 的时候,如果不理解 this 的正确含义,很容易造成错误。这是由于内部 function 的 this 值与它外部的 function 的 this 值是不一样的。代码清单 5中,在
myObj
的func
中有个内部名为inner
的 function,在inner
被调用的时候,this 的值是全局对象,因此找不到名为myVal
的变量。这个时候通常的解决办法是将外部 function 的 this 值保存在一个变量中(此处为self
),在内部 function 中使用它来查找变量。 - 如果在一个 function 之前使用 new 的话,会创建一个新的对象,该 funtion 也会被调用,而 this 的值是新创建的那个对象。如
function User(name) {this.name = name}; var user1 = new User("Alex");
中,通过调用new User("Alex")
,会创建一个新的对象,以user1
来引用,User
这个 function 也会被调用,会在user1
这个对象中设置名为name
的属性,其值是Alex
。 - 可以通过 function 的 apply 和 call 方法来指定它被调用的时候的 this 的值。 apply 和 call 的第一个参数都是要指定的 this 的值,两者不同的是调用的实际参数在 apply 中是以数组的形式作为第二个参数传入的,而 call 中除了第一个参数之外的其它参数都是调用的实际参数。如
func.apply(anotherObj, [arg1, arg2])
中,func
调用时候的 this 指的是anotherObj
,两个参数分别是arg1
和arg2
。同样的功能用 call 来写则是func.call(anotherObj, arg1, arg2)
。
===================================================================
那么我上面的那段代码里面的this是什么呢 是window吗 我加上了代码做试验
var scope = this; toolbar.add({ iconCls : 'graphAdd', id:'aaa', name : 'graphBtn', handler : function(btn) { alert(this==window); //false alert(this==scope); //false alert(this.id); //'aaa' scope.opToolbarClick(btn); } });
那么很明显 handler函数是某个对象的属性 所以他的代码内部this指向的是这个‘某个对象’就是上面handler函数外层的那个{}定义的对象
另一段测试代码
function Container(param) { var that = this; function service() { return this==window; }; alert(service()); //true这个函数不是对象的成员 this指向全局 this.foo1=function(){ return this==window; }; } var a=new Container('aaaa'); alert(a.foo1()); //false foo1函数是对象的成员 this 不是window
我想的可能有不对的地方 望大家不吝赐教
评论
4 楼
豆虫1986
2010-01-20
写错了,是第一个大括号的那个对象,^_^
3 楼
豆虫1986
2010-01-20
lich0079 写道
豆虫1986 写道
scope = this中的这个this指代的是window对象,按楼主的想法,handler中的若写成this,这个this指代的是 {
iconCls : 'graphOrderAdd',
name : 'graphOrder_btn',
handler : function(btn) {
this.opToolbarClick(btn)
}
}
这个对象,这两个this是不一样的。
这属于作用域问题,建议楼主看一下js的作用域
iconCls : 'graphOrderAdd',
name : 'graphOrder_btn',
handler : function(btn) {
this.opToolbarClick(btn)
}
}
这个对象,这两个this是不一样的。
这属于作用域问题,建议楼主看一下js的作用域
这段代码是从一段extjs代码中截取出来的,你写过extjs代码就知道这里的this不是window
你可以这样理解 有这么一个对象
{
toolbar:new Bar(),
opToolbarClick:function(btn){
....
},
foo:function(){
var scope = this;
toolbar.add({
iconCls : 'graphOrderAdd',
name : 'graphOrder_btn',
handler : function(btn) {
scope.opToolbarClick(btn)
}
});
}
}
function(btn) {
this.opToolbarClick(btn)
} 这个函数对象的作用域是他的执行环境的作用域(这个执行环境的作用域就包括了这个scope参数),这里的scope参数就被包含在了执行环境的作用域中,然后就被传递到了这个匿名函数的scope里
推荐你看下http://www.jibbering.com/faq/faq_notes/closures.html 记得看英文原版的
楼主可能曲解了我的意思,我所说的window不是浏览器的window,就拿你这段代码来说,第一个this就是foo这个function对象,楼主的推荐在下会看的,在此谢过。
2 楼
lich0079
2010-01-20
豆虫1986 写道
scope = this中的这个this指代的是window对象,按楼主的想法,handler中的若写成this,这个this指代的是 {
iconCls : 'graphOrderAdd',
name : 'graphOrder_btn',
handler : function(btn) {
this.opToolbarClick(btn)
}
}
这个对象,这两个this是不一样的。
这属于作用域问题,建议楼主看一下js的作用域
iconCls : 'graphOrderAdd',
name : 'graphOrder_btn',
handler : function(btn) {
this.opToolbarClick(btn)
}
}
这个对象,这两个this是不一样的。
这属于作用域问题,建议楼主看一下js的作用域
这段代码是从一段extjs代码中截取出来的,你写过extjs代码就知道这里的this不是window
你可以这样理解 有这么一个对象
{
toolbar:new Bar(),
opToolbarClick:function(btn){
....
},
foo:function(){
var scope = this;
toolbar.add({
iconCls : 'graphOrderAdd',
name : 'graphOrder_btn',
handler : function(btn) {
scope.opToolbarClick(btn)
}
});
}
}
function(btn) {
this.opToolbarClick(btn)
} 这个函数对象的作用域是他的执行环境的作用域(这个执行环境的作用域就包括了这个scope参数),这里的scope参数就被包含在了执行环境的作用域中,然后就被传递到了这个匿名函数的scope里
推荐你看下http://www.jibbering.com/faq/faq_notes/closures.html 记得看英文原版的
1 楼
豆虫1986
2010-01-20
scope = this中的这个this指代的是window对象,按楼主的想法,handler中的若写成this,这个this指代的是 {
iconCls : 'graphOrderAdd',
name : 'graphOrder_btn',
handler : function(btn) {
this.opToolbarClick(btn)
}
}
这个对象,这两个this是不一样的。
这属于作用域问题,建议楼主看一下js的作用域
iconCls : 'graphOrderAdd',
name : 'graphOrder_btn',
handler : function(btn) {
this.opToolbarClick(btn)
}
}
这个对象,这两个this是不一样的。
这属于作用域问题,建议楼主看一下js的作用域
发表评论
-
node npm windows
2018-10-15 16:06 1300在window下npm install, 遇到一 ... -
How to use requirejs in client side
2016-12-05 16:27 483How to use requirejs in client ... -
dojo get post demo
2015-07-31 14:37 1067dojo.xhrGet({ u ... -
dgrid之Grid Pagination 集成分页 后台rest service
2015-05-19 13:09 2387dgrid之Grid集成分页 后台rest serv ... -
angular 1.3.15 表达式bug
2015-04-15 13:41 884不确定这是 angular的还是浏览器的, chrom ... -
书上看来的js闭包列子
2014-01-22 12:19 1524js闭包列子 <html> <h ... -
犀牛书 & JavaScript Web Applications notes
2012-10-20 22:10 1710https://www.evernote.com/shar ... -
犀牛书 笔记
2012-10-15 09:51 5http://www.evernote.com/shard/s ... -
点击其他地方隐藏popup窗口
2011-12-14 16:54 2283现在系统有一个弹出的日期选择窗口, 要求在窗口弹出后, 点击窗 ... -
jqgrid 隔行变底色
2011-10-20 19:07 5291jgrid默认配置没有 隔行变底色的选项 查看源码 看他怎 ... -
twitter search jquery plugin
2011-06-20 16:05 1996详见 http://tweet.seaofclouds.co ... -
js encodeURIComponent encodeURI decodeURI
2011-05-26 15:48 1494js encodeURIComponent enco ... -
jquery hover hasClass insertBefore live blockUI children notice
2011-05-17 18:22 1882hover $(".onenote& ... -
jquery validate
2011-05-05 18:44 1195function(){ $("#re ... -
js 测试 用户名 中文 英文 数字 判断 函数 是否 存在
2010-11-03 20:24 1800/^((\w)|([\u4E00-\u9FA5])){1,20 ... -
css 滤镜 路径
2010-09-13 20:10 1216在ie6处理png透明的代码是: 1. filt ... -
jquery取得text,areatext,radio,checkbox,select的值
2010-07-09 18:21 1504jquery取得 text,areatext,radio,c ... -
js 遍历对象属性
2010-07-05 12:14 1418<!DOCTYPE html PUBLIC " ... -
jQuery 对Select的操作
2010-06-30 20:36 1130语法解释: 1. $("# ... -
国家地区 js 数组
2010-06-30 19:06 4794en var geolocation= [ [" ...
相关推荐
`Presentations-JavaScriptThis-源码.rar`或`.zip`文件很可能是关于这个主题的一份详细讲解材料,包含了一些示例代码和演示。 1. **`this`的基本概念**: `this`在JavaScript中用于引用当前执行上下文的对象,它的...
js原生态函数中使用jQuery中的$(this)无效的解决方法 在JavaScript开发中,使用jQuery的$(this)在原生态函数中可能会出现无效的问题,本文将对此进行详细的分析和解决方法的介绍。 一、问题描述 在JavaScript开发...
在JavaScript中,`this`关键字是一个非常重要的概念,它用于引用当前上下文中的对象。`this`的值在运行时确定,并且根据函数被调用的方式而改变。下面我们将深入探讨`this`的使用方法。 1. **全局作用域与浏览器...
在JavaScript中,`this`关键字是一个至关重要的概念,它在不同上下文中有着不同的指向。`this`在JavaScript中并不像其他静态类型语言(如Java或C++)中的指针那样工作,而是根据函数调用的方式动态确定其值。以下是...
### 详解Javascript中的`this`指针 在深入探讨`this`指针之前,我们首先应当明确`this`在JavaScript中的基本概念与作用。`this`关键字在JavaScript中扮演了一个非常核心的角色,它是一个特殊的变量,用于引用调用...
- 在全局作用域中,`this` 指向全局对象,在浏览器环境中是 `window`,在 Node.js 中是 `global`。 - 在函数调用中,如果函数不是一个方法(即没有被某个对象拥有),`this` 也会指向全局对象。 2. **隐式绑定**...
本文对Javascript this函数进行详细介绍,及知识的总结整理,彻底明白js this 函数该如何使用。 this 代码函数调用时, .1直接调用函数则为this则指向window对象 .2类调用时候指向这个类 .3 方法.apply(obg) ;...
JavaScript中this的指向还没搞明白?来这看看 你就懂啦~
### 面向对象的JavaScript编程:深入了解`this`关键字及类的实现 #### 引言 面向对象编程(Object-Oriented Programming, OOP)是一种编程范式,旨在通过对象来封装数据与操作这些数据的方法。JavaScript 作为一种...
2. **函数没有所属对象(全局环境)**:在非严格模式下,如果函数不在任何对象作用域内被调用,`this` 指向全局对象(在浏览器中是 `window`,在 Node.js 环境中是 `global`)。例如: ```javascript function foo...
Vue.js 是一款流行的前端框架,它的核心特性之一是数据绑定。在 Vue 中,我们通常使用 `data` 选项来声明初始数据。然而,在某些场景下,我们可能需要在运行时动态地添加或修改数据属性,这时就需要用到 `this.$set`...
本文将详细介绍JavaScript中一种常见的事件处理用法——onclick(this)。 首先,我们需要理解什么是onclick事件处理器。在HTML中,onclick是一个事件属性,用于指定当元素被点击时将调用的JavaScript代码。这个属性...
在这个名为"Presentations-JavaScriptThis"的资料包中,很显然,我们将探讨"this"在JavaScript中的各种用法和应用场景。 首先,我们要明白"this"的基本概念。在JavaScript中,"this"引用的是函数调用时的执行上下文...
在JavaScript编程语言中,`this`关键字是一个至关重要的概念,它常常引发初学者的困惑,因为它的值在不同的上下文中可能会有所不同。`this`关键字主要用来引用对象的上下文,或者说是当前执行环境中的对象。在本文中...
在Vue.js应用中,路由是页面之间导航的关键组成部分。`this.$router` 是Vue Router提供的一个实例,用于处理页面的导航。在这个问题中,开发者遇到了使用`this.$router.push`传递`params`参数时无法在目标页面获取到...
### JavaScript中的`this`用法详解 在JavaScript中,`this`关键字的使用十分常见,但也是最容易引起混淆的部分之一。正确理解`this`的工作原理对于编写高效、可靠的代码至关重要。本文将深入探讨`this`在不同上下...
标题和描述提到的"js this函数调用无需再次抓获id,name或标签名",意味着通过正确使用`this`,我们可以避免频繁地使用`document.getElementById`、`document.getElementsByName` 或 `document.getElementsByTagName...
这篇文章主要介绍了JavaScript This指向问题详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 各位小伙伴在面试中被面试官问道this指向问题一定不少吧,同时...
JavaScript中的`this`关键字是一个非常重要的概念,它用于在函数执行时引用当前上下文的对象。在JavaScript中,`this`的绑定遵循四个主要规则:默认绑定、隐式绑定、显式绑定和new绑定。让我们逐一深入理解这些规则...