草庐IT

Prototype_Console

全部标签

javascript - 如何避免 javascript 中的原型(prototype)污染?

在javascript中,可以“覆盖”Object.prototype的属性或方法。例如:Object.prototype.toString=function(){return"somestring";};如果不小心使用,它可能会破坏整个应用程序。是否有任何工具、技术或方法可以避免这种情况(例如,某种不允许开发人员覆盖对象属性的“严格模式”)? 最佳答案 Object.freeze(YourConstructor.prototype)可以帮助保护您的构造函数的关联原型(prototype)对象免遭破坏。来自MDN:TheObject

javascript - JavaScript 中的对象原型(prototype)

我有一些JavaScript代码定义函数getElementsByAttribute如下:Object.prototype.getElementsByAttribute=function(attr){varchildren=this.all||this.getElementsByTagName('*'),ret=[],i,c;for(i=0;i这适用于我测试过的所有浏览器,除了InternetExplorer7(可能更低)——这些浏览器会抛出“对象不支持此属性或方法”。我唯一能想到它不喜欢的是当我定义原型(prototype)函数时已经创建了对象......将函数定义为...好吧,一个

javascript - 如何设置在 console.log 中返回的 JavaScript 对象名称?

那么,这里的第一个问题-请保持温和。我正在与其他一些来自各种非Web编程背景的开发人员一起开发一个相当重的JavaScript项目,我们决定尝试在我们的JavaScript伪类中使用公共(public)和私有(private)方法和属性,纯粹是为了编码实践(即我们知道它没有实际优势或安全性)我们尝试了几种不同的方式来处理公共(public)和私有(private)(即使用局部范围的变量和函数以及用于公共(public)消费的特权方法)并且我们目前已经决定让我们的JavaScript类构造函数实际返回一个对象仅代表其公共(public)接口(interface),有效地隐藏了其他所有内容

javascript - 使用 javascript 对象原型(prototype)扩展类时出现问题

我遇到了这个问题...B是基类,A是派生类...事件虽然A派生自B,但A的各种对象指向B的同一个对象。我知道我已经将B的对象分配给A的原型(prototype),以使A成为B的子对象。但是A的不同对象,应该有不同的地址空间来存放变量吧?你能纠正这个吗?functionB(){this.obj={};}functionA(){}A.prototype=newB();vara=newA();varb=newA();varc=newA();console.log(a.obj==b.obj);//printstrueconsole.log(a.obj===b.obj);//printstrue

Javascript Prototype Chaining父类(super class)构造函数和方法调用

我是JavaScript世界的新手,在尝试原型(prototype)链继承时遇到了这个奇怪的问题。我有3个类(class)//classparentfunctionparent(param_1){this.param=param_1;this.getObjWithParam=function(val){console.log("valueinparentclass"+val);console.log("Constructorparameter:"+this.param);};};//classchildfunctionchild(param_1){this.constructor(pa

javascript - 为什么原型(prototype)函数比默认声明的函数慢 40 倍?

我玩过jsperf.com,发现原型(prototype)函数比“默认”声明的函数慢40倍。String.prototype.contains=function(s){return!!~this.indexOf(s)}=220Kops/s对比functionisContains(str,s){return!!~str.indexOf(s)}=8.5KK操作/秒Here'sajsperftestcase附言我知道原型(prototype)修改不是最好的情况,可以命名为“猴子修补”:) 最佳答案 我认为它很慢,因为字符串基元每次调用一个

javascript - 为什么 ES5 Object 方法没有添加到 Object.prototype 中?

ES5添加了一个number的methods到Object,这似乎打破了JavaScript的语义一致性。例如,在此扩展之前,JavaScriptAPI始终围绕操作对象本身;vararrayLength=[].length;varfirstPosInString="foo".indexOf("o");...新的Object方法是这样的;varobj={};Object.defineProperty(obj,{value:'a',writable:false});...当以下内容更加符合时:varobj={};obj.defineProperty({value:'a',writable:

javascript - console.log 什么时候执行?

我正在尝试使用console.log调试一些非常简单的Javascript,但它输出的变量值直到console.log调用之后才更改,此时变量是“类”成员(Chrome22、Firefox16)。我期望发生的事情的一个例子是这样的:vara=1;console.log(a);a+=20;//consoleoutputsaysais1但是如果变量是“类”成员:vara=newmyClass(1);console.log(a);a.x+=20;//consoleoutputsaysa.xis21如果调用日志时控制台不记录该值,那么它最终决定什么时候记录该值,我该如何解决这个问题!这里是完整

javascript - 为什么在原型(prototype)而不是构造函数中声明实例属性?

我完全理解为什么最好使用原型(prototype)而不是构造函数来定义类方法,(即Useof'prototype'vs.'this'inJavaScript?)但是,我最近遇到了一个HashMapclass在原型(prototype)中定义了count属性,在构造函数中定义了map属性:js_cols.HashMap=function(opt_map,var_args){/***UnderlyingJSobjectusedtoimplementthemap.*@type{!Object}*@private*/this.map_={};/...}/***Thenumberofkeyval

JavaScript:原型(prototype)是静态的同义词吗?

我正在自学来自OOP背景的JavaScript。我正在学习的书让我想,“哇,属性几乎和静态方法或变量一样!”如果是这种情况,我很乐意更多地实现它们以节省一些内存,但在我爱上它们之前,我想确保我正确使用它们。是这样吗?我的逻辑错了吗?我在下面添加了一些示例代码以用作我的问题的上下文。希望它没有过于简单化:functionperson(first,age){this.firstName=first;this.age=age;}person.prototype.sayHello=function(){return"himynameis"+this.firstName+"andIam"+age