草庐IT

oci_new_collection

全部标签

javascript - "new <function>"后面的括号可选吗?

这个问题在这里已经有了答案:Canweomitparentheseswhencreatinganobjectusingthe"new"operator?(6个答案)关闭6年前。我在Chrome控制台中运行了以下一对代码片段,结果相同:test=newfunction(){vara=1;varb=2;varc=3;this.debugBase=function(){console.log(''+a+b+c)};};testdebugBase:function(){console.log(''+a+b+c)}__proto__:Object对比:test2=new(function(){v

javascript - 使用 new 创建对象时是否需要从构造函数返回

如果我有这样的功能:functionApple(){this.color="green";returnthis;}像这样创建对象时:varmy_obj=newApple();returnthis;行是否必要和/或通过语言引用是否有效? 最佳答案 不,返回this不是必需的,但它是有效的。如果返回值是一个对象,new将返回该对象而不是新创建的对象。参见ECMAScript5的第11.2.2和13.2.2点:new运算符调用构造函数(通常是函数)上的内部[[Construct]]方法:11.2.2ThenewOperatorThepro

javascript - Backbone.Collection 通过 id 获取模型

我有一个从服务器获取模型的集合。这行得通,现在我想通过MyCollection.at(0)的id获取一个模型,我得到:child_changes:Array[0]_changing:false_currentAttributes:Object_events:Object_hasComputed:true_pending:false_previousAttributes:Objectattributes:Object_id:"50ef7a63b2a53d17fe000001"author_name:"authorname"bookmark:""info:"bookmarkdescript

javascript - 使用 javascript 小书签在网页中查找 'old' 的所有实例并将每个实例替换为 'new'

我想做的是用JS书签或greasemonkey脚本中的"new"替换网页中所有“旧”实例。我怎样才能做到这一点?我想jQuery或其他框架没问题,因为有黑客可以将它们包含在书签和greasemonkey脚本中。 最佳答案 一个防破坏的函数。这意味着这不会触及任何标签或属性,只会触及文本。functionhtmlreplace(a,b,element){if(!element)element=document.body;varnodes=element.childNodes;for(varn=0;n书签版本:javascript:fu

javascript - Backbone : fetch collection from server

我正在尝试从我的服务器获取一个集合。我使用的是0.3.3版(不是来自github的master)但是我在这个异常中运行:UncaughtTypeError:Cannotuse'in'operatortosearchfor'id'in{id=MyId,active=true}jQuery.jQuery.extend._Deferred.deferred.resolveWith(jquery.js:869)done(jquery.js:6591)jQuery.ajaxTransport.send.callback这是我创建错误的方式:varMyModel=Backbone.Model.ex

javascript - 如果 Crockford 建议我们将它用于原型(prototype)继承,为什么他说不要使用 new 关键字?

我看过一段视频,其中Crockford告诉我们不要使用new关键字。如果我没记错的话,他说要改用Object.create。为什么他告诉我们不要使用new,如果他在他写的这篇文章中使用它来实现原型(prototype)继承:http://javascript.crockford.com/prototypal.html我希望他使用Object.create而不是new,如下所示:functionobject(o){returnObject.create((function(){}).prototype=o);}那为什么他还在用new呢? 最佳答案

javascript - `new Error()` 什么时候比 `Error()` 好?

ES5语言规范clearlystatesError(foo)和newError(foo)做同样的事情。但我注意到在野外,较长的newError(foo)形式更为常见。这有什么原因吗?是否存在使用newError(foo)比使用Error(foo)更可取的情况? 最佳答案 Istheresomereasonforthis?这只是总是用new调用构造函数的习惯。一致性规则!即使它们在没有new的情况下工作也是一种很好的做法,并且被多个样式指南和相关工具推荐。顺便说一句,因为ES6Errorissubclassible,及其子类将需要ne

javascript - 令人困惑的 JavaScript 语句 : "var x = new this();"

我以为我理解了JavaScript原型(prototype)对象的概念,以及[[proto]],直到我看到一些关于类继承的帖子。首先,“JavaScriptOOP-聪明的方式”在http://amix.dk/blog/viewEntry/19038查看实现部分:varparent=newthis('no_init');还有JohnResig的精彩博客上的“简单JavaScript继承”。varprototype=newthis();newthis();到底是什么意思?这个声明对我来说毫无意义,因为我的理解是this指向一个对象而不是构造函数。我还尝试在Firebug中测试语句来解决这个

javascript - 为什么使用 {} 而不是 new Object() 并使用 [] 而不是 new Array() 和 true/false 而不是 new Boolean()?

许多人说您应该避免使用newObject、newArray(),而是使用{}。[]和真/假。使用字面量构造来获取对象或数组的新实例而不是使用new有什么好处?我知道Crockford不喜欢新的,但这是主要论点吗? 最佳答案 与使用各自的构造函数相比,对象和数组文字的优点是:更短、更易读更安全:当Array或Object构造函数被重写时,文字仍然有效可能会更快,但它不太可能成为主要考虑因素(任何瓶颈几乎肯定会起源于代码中的其他地方)在数组的情况下,文字还有一个额外的优势:不可能单独使用Array构造函数创建具有单个成员的数组。例如,[

javascript - new 关键字在幕后做了什么?

我很好奇new关键字除了更改this范围所指的内容外,在后台还能做什么。例如,如果我们将使用new关键字使函数在对象上设置属性和方法与仅使函数返回新对象进行比较,那么新对象还有什么额外的作用吗?如果我不想从函数构造函数创建多个对象,这是首选varfoo2=function(){vartemp="test";return{getLol:function(){returntemp;},setLol:function(value){temp=value;}};}();varfoo=newfunction(){vartemp="test";this.getLol=function(){retu