函数JavaScript秘密花园 - hasOwnProperty,Functions,this

hasownproperty  时间:2021-02-27  阅读:()

JavaScript秘密花园-hasOwnProperty,Functions,thishasOwnProperty

为了判断一个对象是否包含自定义属性而不是原型链上的属性 我们需要使用继承自Object.prototype的hasOwnProperty方法。

注意:通过判断一个属性是否undefined是不够的。 因为一个属性可能确实存在只不过它的值被设置为undefined。hasOwnProperty是JavaScript中唯一一个处理属性但是不需要查找原型链的方法。?

只有hasOwnProperty可以给出正确和期望的结果这在遍历对象的属性时会很有用。没有其它方法可以用来排除原型链上的属性而不是定义在对象自身上的属性。hasOwnProperty作为属性hasOwnProperty as a property

JavaScript不会保护hasOwnProperty被非法占用因此如果一个对象碰巧存在这个属性就需要使用外部的hasOwnProperty函数来获取正确的结果。

?

结论In conclusion

当检查对象上某个属性是否存在时 hasOwnProperty是唯一可用的方法。 同时在使用for in loop遍历对象时推荐总是使用hasOwnProperty方法 这将会避免原型对象扩展带来的干扰。

函数Functions

函数是JavaScript中的一等对象这意味着可以把函数像其它值一样传递。 一个常见的用法是把匿名函数作为回调函数传递对异步函数中。

函数声明The function declaration

?

1 function foo() {}

上面的方法会在执行前被解析hoisted 因此它存在于当前上下文的任意一个地方 即使在函数定义体的上面被调用也是对的。

?

1 foo() ; //正常运行 因为foo在代码运行前已经被创建

2 function foo() {}

函数赋值表达式The function expression

?

1 var foo = function() {} ;

这个例子把一个匿名的函数赋值给变量foo。

?

由于var定义了一个声明语句对变量foo的解析是在代码运行之前因此foo变量在代码运行时已经被定义过了。

但是由于赋值语句只在运行时执行因此在相应代码执行之前 foo的值缺省为undefined。命名函数的赋值表达式Named function expression

另外一个特殊的情况是将命名函数赋值给一个变量。

?

bar函数声明外是不可见的这是因为我们已经把函数赋值给了foo 然而在bar内部依然可见。这是由于JavaScript的命名处理所致 函数名在函数内总是可见的。this的工作原理How this works

JavaScript有一套完全不同于其它语言的对this的处理机制。 在五种不同的情况下this指向的各不相同。

全局范围内 The global scope

?

1 this;

当在全部范围内使用this它将会指向全局对象。 译者注浏览器中运行的JavaScript脚本这个全局对象是window

函数调用Cal l ing a function

?

1 foo() ;

这里this也会指向全局对象。

ES5注意:在严格模式下strict mode 不存在全局变量。 这种情况下this将会是undef ined。 译者注ES5指的是ECMAScript 5是2009-12发布的最新的JavaScript版本。 

方法调用Cal l ing a method

?

1 test.foo() ;

这个例子中 this指向test对象。

调用构造函数Cal ling a constructor

?

1 new foo() ;

如果函数倾向于和new关键词一块使用则我们称这个函数是构造函数。 在函数内部this指向新创建的对象。

显式的设置this Expl icitsetting of this

?

当使用Function.prototype上的call或者apply方法时 函数内的this将会被显式设置为函数调用的第一个参数。

因此函数调用的规则在上例中已经不适用了在foo函数内this被设置成了bar。注意:在对象的字面声明语法中 this不能用来指向对象本身。 因此var obj = {me:this}中的me不会指向obj 因为this只可能出现在上述的五种情况中。 译者注这个例子中如果是在浏览器中运行 obj.me等于window对象。 

常见误解Common pitfalls

尽管大部分的情况都说的过去不过第一个规则译者注这里指的应该是第二个规则也就是直接调用函数时 this指向全局对象 被认为是JavaScript语言另一个错误设计的地方 因为它从来就没有实际的用途。

?

一个常见的误解是test中的this将会指向Foo对象实际上不是这样子的。

为了在test中获取对Foo对象的引用我们需要在method函数内部创建一个局部变量指向Foo对象。

?

that只是我们随意起的名字不过这个名字被广泛的用来指向外部的this对象。在closures一节我们可以看到that可以作为参数传递。

方法的赋值表达式Assigning methods

另一个看起来奇怪的地方是函数别名也就是将一个方法赋值给一个变量。

?

1 var test = someObject.methodTest;

2 test() ;

上例中 test就像一个普通的函数被调用 因此 函数内的this将不再被指向到someObject对象。

虽然this的晚绑定特性似乎并不友好但是这确实基于原型继承赖以生存的土壤。?

6

7 new Bar() .method() ;

当method被调用时 this将会指向Bar的实例对象。

限时新网有提供5+个免费域名

有在六月份的时候也有分享过新网域名注册商发布的域名促销活动(这里)。这不在九月份发布秋季域名促销活动,有提供年付16元的.COM域名,同时还有5个+的特殊后缀的域名是免费的。对于新网服务商是曾经非常老牌的域名注册商,早年也是有在他们家注册域名的。我们可以看到,如果有针对新用户的可以领到16元的.COM域名。包括还有首年免费的.XYZ、.SHOP、Space等等后缀的域名。除了.COM域名之外的其他...

昔日数据:香港云服务器(2G防御)、湖北云服务器(100G防御),首月5折,低至12元/月

昔日数据,国内商家,成立于2020年,主要销售湖北十堰和香港HKBN的云服务器,采用KVM虚拟化技术构架,不限制流量。当前夏季促销活动,全部首月5折促销,活动截止于8月11日。官方网站:https://www.xrapi.cn/5折优惠码:XR2021湖北十堰云服务器托管于湖北十堰市IDC数据中心,母鸡采用e5 2651v2,SSD MLC企业硬盘、 rdid5阵列为数据护航,100G高防,超出防...

VPS云服务器GT线路,KVM虚vps消息CloudCone美国洛杉矶便宜年付VPS云服务器补货14美元/年

近日CloudCone发布了最新的补货消息,针对此前新年闪购年付便宜VPS云服务器计划方案进行了少量补货,KVM虚拟架构,美国洛杉矶CN2 GT线路,1Gbps带宽,最低3TB流量,仅需14美元/年,有需要国外便宜美国洛杉矶VPS云服务器的朋友可以尝试一下。CloudCone怎么样?CloudCone服务器好不好?CloudCone值不值得购买?CloudCone是一家成立于2017年的美国服务器...

hasownproperty为你推荐
手游运营手册游戏发展国主机开发怎么做 怎么开发主机flash导航条FLASH导航条 怎么加入链接?微信如何建群微信如何建群ios系统ios是什么意思 ios系统是什么微信电话本怎么用微信电话本怎么使用呀,我的电话号码是存在手机里面,用这个软件就读取不了电话,我是第一次使用聚美优品红包聚美优品301活动红包的使用规则是什么?王炳坤南北小年为何不同日office2007简体中文版office2007下载安装关闭qq相册图标怎么关闭QQ空间跟QQ相册的图标?小米3大概要多少钱小米3换个屏幕大概多少钱?不要什么大概好像,答案准确点!
vps优惠码cnyvps 快速域名备案 香港新世界电讯 tightvnc 镇江联通宽带 免费smtp服务器 丹弗 美国十次啦服务器 100x100头像 天互数据 河南移动网 美国网站服务器 购买国外空间 in域名 美国独立日 中国电信测速器 湖南idc 乐视会员免费领取 免费主页空间 winds 更多