草庐IT

get_object_vars

全部标签

javascript - try/catch 表达式中的 var 关键字 : JSLint bug or global assignment?

我注意到JSLint的一个有趣结果在研究codereview题。JSLint提示变量在定义之前被使用。这是生成相同结果的代码的缩短版本:(function(){try{vara=0;throw{name:"fakeError"};}catch(e){a=1;}}());我对JavaScript的理解是上面的代码应该等同于:(function(){vara;try{a=0;throw{name:"fakeError"};}catch(e){a=1;}}());事实上,当通过Firebug运行时,这两个示例都不会导致a存在于全局范围内。我看了一下ECMA-262spec的第12.14节,但

javascript - 在嵌套函数中使用 var 声明一个与 parent 参数同名的变量

我正在使用JavaScript编写一些代码并发现了意外行为。我在f中使用嵌套函数g。f有一个名为m的参数。在g中使用和声明同名变量时,会发生一些奇怪的事情:varf=function(m){varg=function(){alert(m);varm=0;};g();};f(1);此代码将导致undefined,而不是我预期的1。将alert语句移动到var行下方会得到有意义的答案0。我想这是因为JavaScript仅将函数用作名称闭包,varm将通过声明附加到函数g,但是m在alert时尚未分配。但我不确定这一点,因为如果函数没有嵌套,我觉得它的行为很好:varg=function(m

javascript - Angular UI 路由器 : decide child state template on the basis of parent resolved object

这是我的app.js文件-我有一个母国和两个子国。两个subview都需要该对象。states.push({name:'parentstate',url:'/parent/:objId',abstract:true,templateUrl:'views/parentview.html',controller:function(){},resolve:{obj:function(OBJ,$stateParams){returnOBJ.get($stateParams.objId);}}});我想使用这个已解析的对象来决定子模板states.push({name:'parentstate.

javascript - VueJS : Best practice for working with global object between components?

有User.js类和用户对象(user=newUser();)。user对象正在所有嵌套组件中使用。User类中有很多重要的方法。如何在任何组件中简单地使用/访问this.user或this.$user及其方法?1-solution(临时工作解决方案):在vuex的store中设置user并在所有组件中定义'数据:data(){return{user:this.$store.state.user}}缺点:在每个组件中,都应该添加。注意:组件太多了。2-solution:将用户添加到Vue的原型(prototype),如插件:Vue.prototype.$user=user缺点:当use

javascript - ES6 值声明后如何判断它是否为 var/const/let?

这个问题在这里已经有了答案:HowtocheckthatES6"variable"isconstant?(4个答案)关闭3年前。我知道我可以通过查看它的声明位置来确定一个值是varconst还是let。但是我想知道-主要是为了调试、开发JS编译器和学术兴趣-是否有可能在创建变量(var/const/let-ness)后找出它的不变性/范围。即doThing(something)会回来let或等价物。就像我们可以使用typeof或something.constructor.name为构造函数确定类型。

javascript - "Object()"和 "new Object()"在 JavaScript 中有何不同?

在JavaScript中,有什么区别varx=Object();和varx=newObject();? 最佳答案 这是直接从ECMAScriptspecification中提取的:15.2.1作为函数调用的对象构造函数当Object作为函数而不是作为构造函数被调用时,它会执行类型转换。15.2.1.1对象([值])当不带参数或带一个参数值调用Object函数时,以下步骤是拍摄:如果值为空,未定义或未定义提供、创建并返回一个新的对象对象完全就像标准内置对象构造函数已被调用相同的参数(15.2.2.1)。简而言之:newObject([

javascript - 如何让 js-mode 正确缩进继续(复合?)var 声明?

如果我使用不同的var语句,例如functionstretchDiv(){varwh=$(window).height();varsz2=wh-((paddingTop+paddingBottom)+(mainTop+2)*2);//thescrollbarhappensonlywhentheheightoftheeltisconstrainedvarsz3=sz2-outTop-2;$('#out').css({'height':sz3+'px'});}然后JSLint提示,告诉我将第二个和第三个与前一个结合起来。如果我遵循这个建议,JSLint会很高兴,但是Emacs的内置js-m

javascript - "{}"和 "new Object()"之间的区别

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:creatingobjects-newobjectorobjectliteralnotation?以下内容之间到底有什么区别:varmyData=newObject();myData["name"]="ATOzTOA";myData["site"]="atoztoa";和varmyData={};myData["name"]="ATOzTOA";myData["site"]="atoztoa";更新我得到的是这个...varmyData={"name":"ATOzTOA","site":"atoztoa",}

javascript - IFRAME 中的 instanceof HTMLElement 不是 Element 或 Object?

尝试通过简单的检查来确定DOM元素isElement=SomeThinginstanceofElement适用于主文档,但不适用于iframe中的(所有?)节点。示例输出(GoogleChrome):(mdiv是主文档中的DIV,idiv是iframe中的DIV)OMGWTFok:mdivinstanceofElement...true...[objectHTMLDivElement]ok:mdivinstanceofObject...true...[objectHTMLDivElement]ko:idivinstanceofElement...false...[objectHTMLD

javascript - jquery.inArray() 与 Object.hasOwnProperty() 之间的性能差异?

我有一种情况可以选择将字符串键的集合实现为一个对象:$.each(objects,function(key,object){collection[key]="doesn'tmatter";});或者一个数组:$.each(objects,function(key,object){collection.push(key);});我希望能够快速确定集合是否包含给定的键。如果集合是一个对象,我可以使用:if(collection.hasOwnProperty(key_to_find)){//foundit!...}else{//didn'tfindit...}如果集合是一个数组,我可以使用: