草庐IT

strict-prototypes

全部标签

javascript - `this` 和 `prototype` 有什么区别? javascript 哎呀

这个问题在这里已经有了答案:Useof'prototype'vs.'this'inJavaScript?(15个答案)关闭8年前。在codecademy.com上学习javascript类(class)时,我变得有点困惑。首先我们学习了如何向类中添加方法:functionDog(breed){this.breed=breed;this.sayHello=function(){console.log("Hellothisisa"+this.breed+"dog");}};varsomeDog=newDog("goldenretriever");someDog.sayHello();然后我

javascript - "delete"- 恢复 native 函数不适用于已更改的原型(prototype),那怎么办?

如果你像这样改变原生函数:window.open=function(a,b,c){alert(2);}然后你就可以deletewindow.open它会恢复原来的功能,但是:如果你像这样改变它的原型(prototype):window.__proto__.open=function(a,b,c){alert(3);}然后delete不会做任何事情=\现在有什么办法恢复它吗? 最佳答案 当您将window.open更改为其他内容时,例如使用window.open='somethingelse';,然后您将隐藏原型(prototype)

javascript - 为什么要使用 Array.prototype.forEach.call(array, cb) 而不是 array.forEach(cb)?

我刚刚查看了今年ng-europesession的一些照片,并注意到一张幻灯片,我认为它可能显示了即将推出的Angular2的一些代码。请参见此处:(来源:https://plus.google.com/u/0/photos/+ThierryLAU/albums/6073085583895256529/6073092865671487010?pid=6073092865671487010&oid=105910465983441810901)我不明白的是:为什么此代码的作者使用Array.prototype.forEach.call(array,cb)而不是较短且(在我看来)等效的版本a

javascript - 为什么 String.prototype 里面的 'this' 指的是对象类型,而不是字符串类型?

我正在尝试扩展字符串以提供其自身的散列。我正在使用Node.js加密库。我这样扩展字符串:String.prototype.hashCode=function(){returngetHash(this);};我有一个看起来像这样的getHash函数:functiongetHash(testString){console.log("typeis"+typeof(testString));varcrypto=require('crypto');varhash=crypto.createHash("sha256");hash.update(testString);varresult=hash

javascript - 在 JavaScript 中什么时候使用 'Array.prototype' 什么时候使用 'this'?

让我们以TheGoodParts一书中的这个例子为例:Array.method('unshift',function(){this.splice.apply(this,[0,0].concat(Array.prototype.slice.apply(arguments)));returnthis;});为什么作者在一处使用了this.splice,而在另一处使用了Array.prototype.slice?我尝试将this和Array.prototype相互交换,但出现如下错误:类型错误:无法读取未定义的属性“切片”但我仍然不确定,如何知道何时应该使用this或Array.protot

eval 反序列化后 Javascript 原型(prototype)未定义

尝试反序列化JSON数据并更新每个对象的原型(prototype)并继承一个通用函数。但是,以下脚本会抛出错误“people[0].getFullName不是一个函数”。反序列化对象的原型(prototype)在分配后似乎未定义。varjson='[{"firstName":"John","lastName":"Smith"},{"firstName":"Nancy","lastName":"Jones"}]';varpeople;eval('people='+json);functionPerson(){}Person.prototype.getFullName=function()

javascript - 字符串对象与文字 - 修改原型(prototype)?

我想知道为什么向字符串文字的原型(prototype)添加方法似乎有效,但添加属性却不行?我正在研究与thisquestion有关的想法,并具有以下代码:String.prototype._str_index1=0;String.prototype._str_reset=function(){this._str_index1=0;};String.prototype._str_substr=function(len){varret=this.substr(this._str_index1,len);this._str_index1=this._str_index1+len;return

javascript - 通过 "this"和 "prototype"分配函数有什么区别?

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Useof'prototype'vs.'this'inJavascript?我对这两种向函数添加方法感到困惑。让我用一个例子来解释。varfoo=function(){this.bar=function(){alert('Iamamethod')}}foo.prototype.baz=function(){alert('Iamanothermethod')}varcar=newfoo();此时我们可以对汽车使用baz和bar方法。好吧,但是它们之间有什么区别。向函数的原型(prototype)或其构造函数添加

javascript - 调用 Function.prototype.method() 时 TypeError : this. prototype is undefined

我正在读《Javascript:好的部分》这本书。现在我正在阅读有关增强类型的章节:Function.prototype.method=function(name,func){this.prototype[name]=func;returnthis;};更新:为什么下面的代码不起作用?js>Function.prototype.method("test",function(){print("TEST")});typein:2:TypeError:this.prototypeisundefined但是下面的代码没有问题:js>Function.method("test",function

javascript - 原型(prototype)和非原型(prototype)方法?

这个问题在这里已经有了答案:Useof'prototype'vs.'this'inJavaScript?(15个答案)关闭8年前。我想知道,JavaScript中的原型(prototype)方法和非原型(prototype)方法有什么区别?非常感谢任何帮助。