jjzjj

string-function

全部标签

javascript - 在 JavaScript 中替换 `String.prototype.valueOf`

我正在构建一个DSL这将受益于能够破解一些JS内部结构。我知道这在一般的JS用法中是一个非常糟糕的主意,但就我的目的而言,这没关系。以下代码工作正常:varstr=newString("blah");str.valueOf=function(){return10}console.log(str*10);//outputs100但这不是:varstr="blah";str.valueOf=function(){return10}console.log(str*10);//outputsNaN(becausestr==="blah")了解内部结构的人可以解释一下这里发生了什么吗?这两个示例

javascript - Function() 构造函数是否没有像 eval 那样被 V8 优化?

我们正在尝试一种通过WebSockets接收网络组件的方法。这些组件包含自定义脚本,它们应该在组件内的上下文中运行。简而言之,我们有一些脚本字符串并想要运行它们。现在我们为此使用eval,像这样:functionctxEval(ctx,__script){eval(__script);//returnthingswiththectx}并按预期工作,但我读到任何包含eval的函数都没有被V8优化。我想像这样将它转换为newFunction():newFunction("ctx",__script)(ctx);这样我可以实现与上面的ctxEval函数相同的效果。我们知道Function是e

javascript - 为什么 function.apply() 不能在 IE 中跨文档边界工作?

我在IE中看到一些奇怪的行为,试图通过function.apply()调用另一个页面中的函数。这是一个简单的测试用例:test1.html:varopened=null;functionapplyNone(){opened.testFunc.apply(opened);}functionapplyArgs(){opened.testFunc.apply(opened,["appliedarray"]);}functioncall(){opened.testFunc("calleddirectly");}functionremoteApply(){opened.testApply(["u

javascript - 迭代值时,为什么当值是数字时 typeof(value) 返回 "string"? JavaScript

我正在使用GoogleChrome浏览器进行此测试:与直觉相反,第一个循环提示“string”三次,而第二个循环提示“number”三次。numarray=[1,2,3];//for-eachloopfor(numinnumarray)alert(typeof(num));//Standardloopfor(i=0;i我原以为两个循环都会警告“数字”三次。第一个循环在JavaScript中是如何实现的?换句话说,如果for-each是语法糖,那么使用标准循环它的等价物是什么?此外,是否有某种方法可以使用标准循环遍历对象的命名空间?我希望使用第二种循环来触及某个对象的每一个方法和属性。

javascript - Javascript 的 Function.toString() 的逆运算

对于Javascript应用程序,我需要能够让用户保存对象的状态。这涉及保存一组以前动态创建或通过GUI创建的自定义函数,并在以后加载这些存储的函数。本质上,我需要序列化和反序列化函数。现在我通过使用Function对象的.toString()方法实现序列化部分:func.toString().replace('"','\"').replace(/(\r)/g,'').replace(/(\n)/g,'').replace(/(\t)/g,'')这给了我这样美丽的“序列化”函数(注意该函数未命名):"function(someParameter){this.someFunctionNa

JavaScript String 对象在 jQuery.post 上被拆分成一个数组

我正在使用jQuery执行ajax调用-其中许多都工作正常,但我在尝试向服务器发送字符串时遇到了一个奇怪的问题。我已将代码缩小为:varx=newString('updateGroup');vary='updateGroup';$.post('page.aspx',{f:x,f2:y},function(data){});然而,当它到达服务器时,请求变量如下:Request["f"]nullstringRequest["f2"]"updateGroup"stringRequest.Form.AllKeys{string[12]}string[][0]"f[0]"string[1]"f[

javascript - 语法错误 : invalid arrow-function arguments (parentheses around the arrow-function may help)

这样的代码会产生一个错误:if(hr>t1[0]||(hr==t1[0]&&min=>t1[1])&&hr错误:SyntaxError:无效的arrow-function参数(arrow-function周围的括号可能有帮助)这是什么意思,它是如何发生的?Google搜索此错误毫无用处。编辑:似乎是使用=>=而不是=引起的。但我仍然很好奇为什么错误是这样表述的,以及箭头函数应该是什么。编辑2.首先,我没有意识到这实际上可能是特定于浏览器的问题。另外,我没有意识到现在人们在浏览器上下文之外的其他地方使用JS。所以,为了说明这一点,我的浏览器是MozillaFirefox25.0.1。

javascript - 错误 : Zeptojs Animate Is Not A Function

zeptojs文档here当我使用$().animate函数时抛出如下错误:TypeError:$(...).animate不是函数而我使用的版本是页面提供的。 最佳答案 $(...).animate在zeptofx模块中。它不再在zepto的基本主要发行版中!http://zeptojs.com/#modules 关于javascript-错误:ZeptojsAnimateIsNotAFunction,我们在StackOverflow上找到一个类似的问题:

javascript - "bar"中 "var foo = function bar (){ ... }"的用途是什么?

在DouglasCrockford的书中,他将递归函数写为:varwalk_the_DOM=functionwalk(node,func){func(node);node=node.firstChild;while(node){walk(node,func);node=node.nextSibling;}}我从未见过定义为varfoo=functionbar(){...}的函数-我总是看到声明的右侧是匿名的:varfoo=function(){...}声明右侧的名称walk的唯一目的是缩短walk_the_DOM的调用吗?它们似乎成为相同功能的不同名称。也许我误解了这段代码的工作原理。

javascript - String 和 Array 泛型方法将在未来被弃用

在下面的链接(MDN站点)上它说“字符串泛型是非标准的,已弃用并且将来可能会被删除。请注意,如果不使用下面提供的填充程序,您不能跨浏览器依赖它们。“他们所指的方法是否是他们在该声明下方提供的垫片中列出的方法?这是我见过的唯一提到短语“字符串泛型”的地方,所以让我很困惑。对于数组泛型也有同样的问题,因为该站点也提到了类似的情况。https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String#String_generic_methodshttps://developer.mozi