- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是最奇怪的事情。我的代码如下:
function menuSwipe(init){
dojo.query('div.fill div.container div.menu div.group ul').forEach(function(item){
dojo.fx.wipeOut({
node: item,
duration: 1
}).play();
dojo.query('li', item).forEach(function(childrenItem){
if (dojo.hasClass(childrenItem, 'active'))
childrenItem.parentNode.className = 'items active';
});
if (item.className == 'items active') {
dojo.query('div.category', item.parentNode).forEach(function(parentItem){
setTimeout(function(){
menuOpen(parentItem, init);
doGrayscale(parentItem);
}, 100);
});
}
});
}
基本上 init
会保留在内存中,直到进入 if (item.className == 'items active')
条件。之后它变为undefined
。这是我设置的 bool 值。只要它在 if (item.className == 'items active')
之前,它就会保留其值。我没有理由这样做。我尝试执行 this.init =
并将其设置为 var init = init
。有谁知道或者有什么方法可以在整个功能中保留它的值(value)?它不是 init 命名,我尝试了不同的名称,它仍然做同样的事情。
谢谢,达伦
最佳答案
问题是在函数完成后运行超时,因此在超时运行时 parentItem 变量超出了范围。
在该范围内创建一个局部变量,以便为超时函数创建一个闭包。这样每次迭代都有自己的变量:
dojo.query('div.category', item.parentNode).forEach(function(parentItem){
var itemCopy = parentItem;
window.setTimeout(function(){
menuOpen(itemCopy, init);
doGrayscale(itemCopy);
}, 100);
});
关于Javascript 函数变量突然变得未定义?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4047986/
我在 android 代码中使用 asmack XMPP。我可以正常登录 XMPP 服务器,但是当我尝试创建新用户时出现问题。我想要实现的是: 以管理员身份登录。 创建一个新用户。 从管理员注销。 以
这是我的标记页面,其中有一个按钮可以从数据库中搜索数据并显示在网格中 这是我背后的代码 if (!IsPostBack) { LblInfo.Text = "Page Load
当我多次将相同的 float 值插入到我的集合中时,本应花费恒定时间的 x in s 检查变得非常慢。为什么? 时序x in s的输出: 0.06 microseconds 0.09 mi
我有一个小型聊天客户端,可以将所有历史记录存储在 sqlite 数据库中。当用户单击我的应用程序中的 history 选项卡时,我的应用程序会获取所有相关历史记录并将其显示在 QWebView 中。我
我是一名优秀的程序员,十分优秀!