草庐IT

VAR_LOCALE_USER_DEFAULT

全部标签

javascript - 添加到 ace-editor 明智的自动完成 : List user-defined functions and variables (javascript language)

我想将用户定义的函数和变量列表添加到ace编辑器的自动完成功能中。为此,我想检查用户插入到文档中的所有代码,找到定义的函数(及其参数)、定义的变量及其作用域等。主要问题这些数据是否已经在ace源代码(或语言插件)的某处计算出来,我可以通过某种方式获取它?`我想要什么例如,如果用户插入这样的代码:varvar0='abcd';functionfoo(var1,var2){varvar3='efg';}我想在自动完成框中添加名为“foo”的函数,它有两个参数——var1和var2。我还想将var0添加到变量列表中,并在用户在定义的范围内(在函数中)写入时添加var3。我已经知道的:我知道如

JavaScript 本地作用域 : var vs. this

我似乎无法理解JavaScript变量作用域的特定情况。与我发现的其他示例和问题不同,我对嵌套函数的范围界定很感兴趣。我在thisJSFiddle设置了一个示例.相关部分如下:functionMyObject(){varself=this;vara=1;this.b=2;varinnerMethod=function(){//1and2:directreferencelogMessage("a="+a);//a=1//logMessage("b="+b);//Error:bisnotdefined//3and4:usingthislogMessage("this.a="+this.a)

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 - Jest : Mock ES6 Module with both default and named export

我有一个带有默认导出和命名导出的ES6模块:/**/src/dependency.js**/exportfunctionutilityFunction(){returnfalse;}exportdefaultfunctionmainFunction(){return'foo';}它被第二个ES6模块使用:/**/src/myModule.js**/importmainFunction,{utilityFunction}from'./dependency';//EDIT:Fixedsyntaxerrorincodesample//exportdefaultmyModule(){expor

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 - ES6 值声明后如何判断它是否为 var/const/let?

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

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 变量 : var a =(3, 4,7);

这个问题在这里已经有了答案:WhatdoesthecommaoperatordoinJavaScript?(5个答案)关闭4年前。vara=(3,4,7);console.log(a);//Outputis7您能否解释一下我们如何获得输出7?

javascript - 在 Opera User JavaScript 中使用 jQuery

我想知道是否可以在OperaUserJavaScript内加载jQuery,这样我就可以在其中使用jQuery功能,即使在当前未使用jQuery的页面上也是如此。 最佳答案 我刚刚编写了一个OperauserJS,它是我从GoogleChrome扩展程序转换而来的,可以轻松加载jQuery,但在Opera中我不得不使用另一种解决方案,并且我想对我的代码进行最少的更改。我只是在文档的header中附加了一个新的脚本标记,其中包含一个有效的jQuery源代码。它会在DOM准备就绪之前开始下载。这是我的工作解决方案,希望对您有所帮助!//

javascript - angularjs + ui 路由器 : redirect to login page when user is not logged in on each state change

我正在使用angularjs和ui-router构建一个简单的博客应用程序,我想监听每个状态变化并检查用户是否已登录。如果他没有登录,我想将他重定向到登录页面。场景非常简单,我试图实现thissolution没有运气。这是相关代码:app.config(function($stateProvider,$urlRouterProvider){$stateProvider.state('app',{url:'',abstract:true});$urlRouterProvider.otherwise('blogs');});app.run(function($rootScope,$stat