作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我这里有这段脚本,我想在其中向上滑动我的 ul 元素,然后在执行向上滑动后,我想出于 CSS 原因删除“open”类。我做错了什么?
jQuery(this).parent().children("ul").slideUp(500);
setTimeout(function(){
var elementToRemove = jQuery(this).parent();
elementToRemove.removeClass("open");
}, 500);
最佳答案
this
在回调函数中指的是全局对象,而不是事件目标。
两种解决方案:
使用箭头函数(保留 this
上下文):
jQuery(this).parent().children("ul").slideUp(500);
setTimeout(() => {
var elementToRemove = jQuery(this).parent();
elementToRemove.removeClass("open");
}, 500);
或者保存指向 this
对象的链接:
jQuery(this).parent().children("ul").slideUp(500);
let that = this;
setTimeout(function(){
var elementToRemove = jQuery(that).parent();
elementToRemove.removeClass("open");
}, 500);
关于javascript - setTimeout() 不适用于 jQuery(this),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42051296/
我是一名优秀的程序员,十分优秀!