javascript - jQuery .toogleClass 函数用于切换元素类并在事件期间执行某些操作

标签 javascript jquery html toggle

我正在尝试使用 jQuery ToogleClass 来切换元素。 我想从关注图标切换到取消关注图标,并在每次点击期间执行某些操作(例如 ajax 调用、警报或其他操作)。所以我打算做的是使用 toogleClass(function(){}) 来实现此功能。

HTML:

    <a class="follow button tiny circle">
        <i class="fa-2x fa fa-eye"></i>
    </a>

JS:

    $("div.up-right a").click(function(){

    $(this).find("i").toggleClass(function(){
        if($(this).parent().hasClass("follow")){
            $(this).parent().removeClass( "follow" ).addClass( "unfollow" );
            return "fa-eye-slash";
        }else {
            $(this).parent().removeClass( "unfollow" ).addClass( "follow" );
            return "fa-eye";
        }

});

我想做的是,当我点击时,我想更改父级中的类(关注<->取消关注)和(fa-eye 到 fa-eye-slash)并执行某些操作。

请看一下这个fiddle

注意:我正在关注这个jquery .toggleClass doc

最佳答案

您可以创建一个简单的切换函数,并为其指定一个元素、要设置的类名和要取消设置的类名。如果父级有“follow”类,您可以设置“unfollow”并取消设置“follow”。 child 也是如此。只需确保将正确的元素传递给函数即可。

$(".up-right a").click(function(){
    $(this).hasClass('follow') ? toggle($(this), 'unfollow', 'follow')
                               : toggle($(this), 'follow', 'unfollow');
    $(this).hasClass('follow') ? toggle($(this).find('i'), 'fa-eye', 'fa-eye-slash')
                               : toggle($(this).find('i'), 'fa-eye-slash', 'fa-eye');
});

function toggle (el, set, unset) {
    $(el).addClass(set);
    $(el).removeClass(unset);
}

关于javascript - jQuery .toogleClass 函数用于切换元素类并在事件期间执行某些操作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29408535/

相关文章:

javascript - Vue 中的父子交互

javascript - 如何使用JQuery获取真实图像高度?

javascript - 如何逐渐设置正在(冒泡)排序的元素的样式?

Javascript : Append text into div?

html - 在 Ionic 中使用 API 执行登录时出现 JSON 错误

javascript - 在 Backbone.js 中绑定(bind)它

javascript - Node - 无数据创建的 ES 索引

javascript - 将特殊的 css 背景应用于 cytoscape.js 边缘

jquery - 使用 Ajax jQuery 提交 Django 表单的简单方法

javascript - 两个 Angular div,我需要隐藏一个 div 并在按下 div 中的按钮时显示另一个 div