javascript 是否允许使用别名 eval? 以下代码的第一部分行为异常(显示 1、1),但第二部分没有(显示 1、2)。 对 ECMA 脚本或 mozilla 文档的引用会有所帮助,但我找不到。
<html>
<script type="application/javascript;version=1.8">
(function(){
eval('var testVar=1');
alert(testVar);
var eval2=eval;
eval2('var testVar=2');
alert(testVar);
})();
(function(){
eval('var testVar=1');
alert(testVar);
eval('var testVar=2');
alert(testVar);
})();
</script>
</html>
最佳答案
您不能“别名”eval 并期望它表现相同。就那么简单。为什么? eval 不是函数。
发生的事情是,当您调用 eval2 时,您正在设置变量“缓存”以使用全局变量。因此,通过在其中设置一个变量,您就是在设置一个全局变量。但是,退出时,变量“缓存”返回到函数作用域。这就是为什么第二个 alert 显示 1 - 全局变量被函数级别 1 隐藏。
这在 ECMAScript 的附件 E(第 239 页)中有说明(重点是我的)
10.4.2: In Edition 5, indirect calls to the eval function use the global environment as both the variable environment and lexical environment for the eval code. In Edition 3, the variable and lexical environments of the caller of an indirect eval was used as the environments for the eval code.
“输入评估代码”的完整定义在 §10.5.2(第 58 页)(强调我的)中定义
关于Javascript eval 别名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17770754/
假设我有一段Ruby代码,我想在其中为一个方法设置别名(我不知道为什么;让我们假设我有一个很好的理由)。classStringalias_method:contains?,:include?end我可以在本节之后删除这个别名吗? 最佳答案 remove_method在大多数情况下应该有效。但是,如果您的alias_method覆盖了现有方法,您可能需要通过单独的alias_method调用来保存原始方法。#assuming:contains?isalreadyamethodalias_method:original_contains
我有一个名为link_to_admin的方法然后我给另一个方法取了别名simple_link_todeflink_to_admin(name,url,options={})#Mystuffherelink_to(name,url,options)endalias_method:simple_link_to,:link_to_admin如果我调用link_to_admin,我会遇到一个问题,我想将值打印到标记例如deflink_to_admin(name,url,options={})#Mystuffheremenu=""menu#{link_to(name,url,options)}"
我正在尝试将Ruby1.9.3应用程序升级到2.0,除了一个小问题外,一切似乎都很顺利。我写了一个模块,我将其包含在我的模型中以覆盖activerecorddestroy。它将现有的destroy方法别名为destroy!,然后覆盖destroy以更改记录上的deleted_at时间戳。仅当我升级到ruby2.0时,destroy!不再破坏记录,但其行为就像我的新覆盖方法一样。知道为什么会这样吗?下面是更相关的代码部分。完整要点here.defself.included(base)base.class_evaldoalias_method:destroy!,:destroyalia
我正在使用Rubyv1.9.2和RubyonRailsv3.2.2gem。我有以下模块moduleMyModuleextendActiveSupport::Concernincludeddodefself.my_method(arg1,arg2)...endendend我想为类方法my_method起别名。因此,我声明了以下(不工作)代码:moduleMyModuleextendActiveSupport::Concernincludeddodefself.my_method(arg1,arg2)...end#Note:thefollowingcodedoesn'twork(itrai
我有一个名为“计算器”的模块,我想将其包含在“产品”类中。Calculator将扩展“Product”,它将类方法复制到Product上。这些类方法之一是“memoize”。我的想法是我可以做这样的事情:moduleCalculatordefself.extended(base)base.memoize:foo_barendend以内存方法(特别是类方法)为目的:foo_bar。在memoize内部,我调用方法“alias_method”,它试图将类方法别名为不同的名称(此处为:foo_bar)。这失败了。Memoize看起来像这样:moduleCalculator(theextend
我读过一些像这样的别名方法:alias:original_method:method对我来说,这看起来像是ruby中的符号。如果我像这样输入别名有什么区别:aliasoriginal_methodmethod结果会不会不同? 最佳答案 与documentation似乎没有区别:Thealiaskeywordismostfrequentlyusedtoaliasmethods.Whenaliasingamethodyoucanuseeitheritsnameorasymbol:aliasnew_nameold_namealias:ne
acts_as_taggable_on实现效果很好,但我还需要声明标签别名。我找到了一个声称这样做的插件,acts_as_taggable_with_aliases,但最后一次提交是在2009年并且不在gem存储库中,所以我认为该项目现在已经死了。有什么办法可以实现吗? 最佳答案 也许你可以创建自己的模型来支持这个(以及你想要的任何其他东西)......我认为您可以通过执行以下操作来实现:classTagtrueendclassModelIWantToBeTagged:taggableendmoduleModelTaggingdef
当我尝试在我的应用程序中加载任何yaml文件时,出现此错误:Psych::BadAlias:Unknownalias:default/Users/luizkowalski/.rbenv/versions/2.2.3/lib/ruby/2.2.0/psych/visitors/to_ruby.rb:385:in`visit_Psych_Nodes_Alias'/Users/luizkowalski/.rbenv/versions/2.2.3/lib/ruby/2.2.0/psych/visitors/visitor.rb:15:in`visit'/Users/luizkowalski/.
我正在尝试为使用Ruby的特殊$&(returnslastregexmatch)的方法起别名。我可以手动执行此操作并且有效:original=String.instance_method(:sub)String.send(:define_method,:sub)do|*args,&block|puts"called"original.bind(self).call(*args,&block)end"foo".sub(/f/){$&.upcase}called#=>"Foo"但是,如果我尝试编写一个为我执行此操作的方法,它会失败:defprogramatic_alias(klass,me
我想为一个原始方法设置两个别名,但我看不到alias_method一次创建多个别名的能力,而是一个接一个。那么有没有可能改变这个:alias_method:aliased_first_method,:first_methodalias_method:aliased_first_method?,:first_method像这样:alias_method[:aliased_first_method,:aliased_first_method?],:first_method我对创建自定义方法不感兴趣。 最佳答案 我认为没有比使用每个更好的