草庐IT

return_var

全部标签

javascript - 'var' 声明的变量和 'this' 在 Javascript 中创建的属性有什么区别?

首先使用varfunctiontestCode(some){varsomething=some;}第二次使用这个functiontestCode2(some){this.something=some;} 最佳答案 在第一个函数中,something是一个private(局部)变量,这意味着它在函数外是完全不可访问的;而在第二个中,它是一个public实例变量。设置变量的上下文将取决于您调用函数的方式:>testCode2("foo");//thiswillrefertodocument.window>something"foo">>

javascript - 理解 Double return 语句是 Javascript

我是JS的新手,基本上每天都在学习新东西,我只是在学习诸如如何动态更新数组之类的东西。不管怎样,我通常会尝试从网上获取干净的JS片段并调试它们,直到我掌握它的真正含义。所以这是我今天发现的一个片段:vararray1=[{tagId:1,tagName:'tag1'},{tagId:2,tagName:'tag2'},{tagId:3,tagName:'tag3'},{tagId:4,tagName:'tag4'}];vararray2=[{tagId:1,tagName:'tag1'},{tagId:2,tagName:'tag2'},{tagId:8,tagName:'tag8'}

javascript - browserify-shim 在 var 范围内时不导出隐式全局变量

根据browserify-shim文档,您可以通过在package.json中使用以下语法来指定browserify-shim需要从遗留模块公开哪些全局变量:{"browserify-shim":{"legacyModule":"myVar"}}我希望可以通过require('legacyModule')和window.myVar访问遗留模块。根据我的经验,如果我尝试填充的非commonjs模块使用window.myVar=x或仅使用myVar=x,则该模块会全局公开并且可按预期通过require()获得。但是,当遗留模块使用varmyVar=x时,这就是导致问题的原因,因为该模块只能

javascript - 在 "var new_function = function name(){};"中用 javascript 定义函数名有什么好处吗?

当我运行一个程序来更改我的javascript代码的某些部分时,它在将var声明为函数时出现错误,如下所示:varsome_function=functionname(args){//dostuff};代码本身有效,但我只是想知道是否可以删除我发现的所有函数的“名称”(因为它不会在分析我的javascript的其他问题中破坏它)或者它是否可以它可能有我看不到的任何用途。删除“名称”:varnew_function=function(){/*dostuff*/};注意:它第一次出现的原始文件在jquery-1.6.4.js中在:jQuerySub.fn.init=functioninit

javascript - d3 中身份函数 ("function(d) { return d; }"的简写是什么?

查看d3文档,我看到这段代码(身份函数)到处重复:function(d){returnd;}d3中是否有内置方法来执行此操作?我知道我可以创建自己的无操作身份函数并在任何地方使用它,但似乎d3应该提供这个。 最佳答案 我想知道为什么没有d3.identity函数作为库的一部分,而且找不到没有的理由。从性能的Angular来看,定义恒等函数比重用Object构造函数提供更好的性能。如果您在不同类型之间重用相同的标识函数,则差别不大。一些performancetestsarehere.所以在我的例子中,我滥用了D3并自己添加了函数:d3

javascript - let vs var 在 nodejs 和 chrome 中的性能

当我在chrome和nodejs中测试以下代码时,我得到以下信息:Chrome:forloopwithVAR:24.058msforloopwithLET:8.402msNodeJS:forloopwithVAR:4.329msforloopwithLET:8.727ms据我了解,由于block作用域,LET在chrome中更快。但是有人可以帮我理解为什么它在NodeJS中是相反的吗?还是我遗漏了什么?"usestrict";console.time("forloopwithVAR");for(vari=0;iPS:不确定这是否不是测试性能的理想方式。 最佳

javascript - 为什么要在这个 var 声明中将这个变量赋值给它自己?

我正在阅读BenCherry的“JavaScriptModulePattern:In-Depth”,他有一些我不太理解的示例代码。在Cross-FilePrivateState标题下,有一些示例代码如下:var_private=my._private=my._private||{}这看起来和写这样的东西没什么不同:var_private=my._private||{}这里发生了什么,这两个声明有何不同? 最佳答案 var_private=my._private=my._private||{}这一行的意思是如果my._private存

javascript - 未捕获的语法错误 : Unexpected token return - still no answer?

所以这个标题有很多问题,但是,我能找到的所有答案似乎都提到了一些在某些特定情况下有效但在其他情况下没有帮助的黑客。许多人关心jQuery或Ajax,但问题是纯JavaScript在非常基础的层面上出现:functionf(){false||(returntrue);}这个函数声明(没有执行)抛出未捕获的语法错误:意外的token返回在Chrome和语法错误:Return语句仅在函数内部有效在Safari中。但是这个函数没有:functionf(){false||(a=true);returntrue;}谁能解释这种奇怪的行为? 最佳答案

javascript - ember-cli 支持每个助手中的 Handlebars @vars(即,@index、@key、@first、@last)

每当我有一个在每个助手内部使用@vars变量(即@index、@key、@first、@last)的Handelbars模板时,我都会在ember-cli中遇到编译错误。(请参阅http://handlebarsjs.com/#iteration以获取有关each帮助程序中这些@vars变量的文档。)下面是一个使用ember-cli构建的简单应用程序,仅包含添加到程序中的两个文件:routes/application.js和templates/application.hbs。这篇文章的底部是ember-cli给出的编译错误信息的截图。我的代码有错误吗?或者这是我应该在github@ht

javascript - 猎犬.js : Transform the data returned by a remote source?

我正在使用带有远程API的Bloodhound,我需要转换从远程API返回的结果。APIURL是https://www.googleapis.com/books/v1/volumes?q=quilting它返回一个具有items属性的对象,该属性是一个列表。我需要将该列表返回给Typeahead,而不是顶级对象。Bloodhound文档说thereisatransformfunctionthatissupposedtodothis,但我无法让它工作。这是我的代码:varbooks=newBloodhound({datumTokenizer:function(d){returnBlood