作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在为一个项目使用 jQuery 和语义 UI,但我对第二个 this
所指的内容感到困惑。这第二个指的是什么?顺便说一句,我是 jQuery 的新手。我希望第二个 this 引用 #sideBar
a 但每次我尝试添加类时它都不起作用,
我想删除所有类,然后向所有类添加项目,然后获取 anchor 标记的文本内容,并使用名称为 textContent 的类设置该 anchor 标记的属性。
$('#sideBar a').on('click', function(){
$('#sideBar a').removeClass().addClass("item");
var addC = ($(this).text());
$(this).addClass(addC);
});
谁能告诉我如何做到这一点,顺便说一句,我对 apply call 和 bind 在 javascript 中有一些了解
最佳答案
this
内部和带有非箭头函数的事件监听器将成为您的事件目标:
$('#sideBar a').on('click', function (event) {
// next line removes all classes from all anchor elements that are children of #sideBar then adds the class item to each of them
$('#sideBar a').removeClass().addClass("item");
// sets addC to whatever the event target's text is
var addC = ($(this).text());
// adds the text stored in addC as a class to the event target
$(this).addClass(addC);
console.log(this === event.target); // logs true
});
编辑:我刚刚意识到我没有回答你的问题:
$(this).parents('#sideBar').first().addClass(addC);
而不是 $(this).addClass(addC);
应该可以解决问题。
关于javascript - 在此上下文中,关键字 this 指的是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44787564/
我是一名优秀的程序员,十分优秀!