javascript - 在此上下文中,关键字 this 指的是什么?

标签 javascript jquery html this semantic-ui

我正在为一个项目使用 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/

相关文章:

javascript - iframe-resizer:无法禁用自动调整大小

javascript - Javascript 中 opener 的跨域更新哈希

javascript - 如何手动从 Bootstrap 中关闭 Web 模式对话框?

javascript - 匹配除尖括号之外的单词边界

javascript - 为什么我应该使用 & 而不是 &?

javascript - 谷歌地图是我的 Ember 组件中的一个灰色框

javascript - 限制用户编辑特殊字符后的字符 - Jquery

javascript - 如何使用Jquery在javascript onClick事件中传递参数?

html - CSS 菜单背景

javascript - 如何在 IE 中从 Javascript 访问 XHR responseBody(用于二进制数据)?