我正在为Wordpress编写一个TinyMCE插件,我只是遇到了一个小问题:我是如何处理问题的。基本上,我使用的是依赖计数器i
的循环。循环负责构建一个包含TinyMce详细信息的数组。其中之一是传递给i
计数器的函数调用。
但是当然,当点击实际注册的时候,计数器总是在它的最大值。我在循环中使用let
临时解决了这个问题。下面是循环:
for(let i = 0; i <= pmsb.config.length - 1; i++) {
menu[i] = {
text: pmsb.config[i].title,
onclick: function() {
open_dialog(i);
}
}
}
我知道let
不受很好的支持,而且这是一个Wordpress插件,我无法真正控制我的目标用户将使用的浏览器。
因此,在上述循环的情况下--如何使函数调用接收正确的数字(正如let
所做的)?
发布于 2016-01-15 15:42:06
而不是使用for
循环,而是使用forEach
-结果回调将自动接收索引作为一个参数,该参数将在作用域中正确绑定:
pmsb.config.forEach(function(config, i) {
menu[i] = {
text: config.title,
onclick: function() {
open_dialog(i);
}
}
});
如果(看起来很可能) pmsb.config[i]
到menu[i]
之间有一对一的映射,那么最好还是使用.map
而不是forEach
。
var menu = pmsb.config.map(function(config, i) {
return {
text: config.title,
onclick: function() {
open_dialog(i);
}
}
});
https://stackoverflow.com/questions/34814689
复制相似问题