"this" 的六项正面与侧面
我们使用函数表达式创建了一个函数,并将其指定给对象的 user.sayHi 属性。 随后我们像这样 user.sayHi() 调用它。用户现在可以说话了! 作为对象属性的函数被称为 方法。 所以,在这我们得到了 user 对象的 sayHi 方法。 当然,我们也可以使用预先声明的函数作为方法,就像这样:
三、方法简写在对象字面量中,有一种更短的(声明)方法的语法:所示,我们可以省略 "function",只写 sayHi()。 说实话,这种表示法还是有些不同。在对象继承方面有一些细微的差别(稍后将会介绍),但目前它们并不重要。在几乎所有的情况下,较短的语法是首选的。 四、方法中的 “this”通常,对象方法需要访问对象中存储的信息才能完成其工作。 例如,user.sayHi() 中的代码可能需要用到 user 的 name 属性。 为了访问该对象,方法中可以使用 this 关键字。 this 的值就是在点之前的这个对象,即调用该方法的对象。果我们在 alert 中以 this.name 替换 user.name,那么代码就会正常运行。 五、“this” 不受限制在 JavaScript 中,this 关键字与其他大多数编程语言中的不同。JavaScript 中的 this 可以用于任何函数,即使它不是对象的方法。 下面这样的代码没有语法错误:个规则很简单:如果 obj.f() 被调用了,则 this 在 f 函数调用期间是 obj。所以在上面的例子中 this 先是 user,之后是 admin。 在没有对象的情况下调用:this == undefi。 在非严格模式的情况下,this 将会是 全局对象(浏览器中的 window,我们稍后会在 全局对象 一章中学习它)。这是一个历史行为,"use strict" 已经将其修复了。 通常这种调用是程序出错了。如果在一个函数内部有 this,那么通常意味着它是在对象上下文环境中被调用的。 解除 this 绑定的后果如果你经常使用其他的编程语言,那么你可能已经习惯了“绑定 this”的概念,即在对象中定义的方法总是有指向该对象的 this。 在 JavaScript 中,this 是“自由”的,它的值是在调用时计算出来的,它的值并不取决于方法声明的位置,而是取决于在“点符号前”的是什么对象。 在运行时对 this 求值的这个概念既有优点也有缺点。一方面,函数可以被重用于不同的对象。另一方面,更大的灵活性造成了更大的出错的可能。 这里我们的立场并不是要评判编程语言的这个设计是好是坏。而是要了解怎样使用它,如何趋利避害。 六、箭头函数没有自己的 “this”
箭头函数有些特别:它们没有自己的 this。如果我们在这样的函数中引用 this,this 值取决于外部“正常的”函数。 (编辑:大同站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |