草庐IT

Prototype_Console

全部标签

javascript - 在 javascript 中的对象扩充期间什么时候应该使用 "prototype"?

我对javascript中的“原型(prototype)”概念感到困惑。当我定义一个对象时,以下两种方法似乎都有效:myObject={};myObject.prototype.method1=function(){...};myObject.prototype.method2=function(){...};myObject.prototype.method3=function(){...};和...myObject={};myObject.method1=function(){...};myObject.method2=function(){...};myObject.method

javascript - 为什么要使用带参数的 Array.prototype.slice.call

我正在使用apply调用一个方法,但我不知道我将传递多少个参数:目前我的代码是这样的:selectFolder:function(e){e.preventDefault();this.addSelectedClass.apply(this,Array.prototype.slice.call(arguments));},我使用Array.prototype.slice的唯一原因是因为它在大多数示例中都是如此。为什么我不只是像这样传递参数:this.addSelectedClass.apply(this,arguments); 最佳答案

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 - console.log 是否以不同方式对待 'this'?

为什么会出现下面的语句:(function(){console.log(this);}).apply(String("hello"));显示以下输出String{0:"h",1:"e",2:"l",3:"l",4:"o",length:5}而不是简单的:hello这种行为是解释器内置的还是有办法检测传递的引用类型? 最佳答案 你得到一个对象而不是字符串作为函数输出的原因是默认情况下javascript'this'对象总是被强制为一个对象。但是,如果您使用带有“usestrict”的严格格式的javascript,则此功能将被禁用,您

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 - console.log 或 utils.inspect 的隐藏属性

我正在使用sails.jswaterlineorm。现在这不是一个特别的sails问题,但我必须放置一些上下文,所以当你创建一个记录时,你会得到一个包含创建数据的对象。如果该记录关联了其他记录(集合),则它具有与返回对象中的记录相关的键,但这些键是getter/setter,即使这些相关对象没有数据。我简化了一些事情只是为了揭示要点。这是我的用户模型:varUser={attributes:status:{type:'string'}images:{collection:'Image'}}假设,我在一个用户模型上执行了一个创建查询,该模型关联了一个图像集合。userRecord是查询返

javascript - 从控制台提取 console.log 方法

考虑到console未被重写并引用native对象,console.log方法(可能还有其他)是从console中提取的反对varlog=obj.log=console.log;//insteadofconsole.log.bind(console)log(...);obj.log(...);它在浏览器和Node兼容性方面是否100%安全?大量带有绑定(bind)console.log的JS示例(可能过于说明性)表明它可能不是。 最佳答案 浏览器在它们的console实现上有所不同,似乎只有基于WebKit/Blink的浏览器(Ch

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