flat ui switch 改变状态而不响应事件

Flat UI 是一套精美的扁平风格 UI 工具包,基于 Twitter Bootstrap 实现。这套界面工具包含许多基本的和复杂的 UI 部件,例如按钮,输入框,组合按钮,复选框,单选按钮,标签,菜单,进度条和滑块,导航元素等等。

对于我们这些不会前端的小码农来说,是绝对的神器。

但也正是因为不了解前端,所以哪怕是丁点的问题,对我们来说都是痛不欲生。

 

这次让我痛不欲生的便是flat ui的switch组件。

该组件是用来替代 checkbox 的组件, 关于它的用法,可以参见这里

 

switch有两种状态,开启和关闭

组件如图所示:

 

对于该组件的初始化、响应事件可以这样写:

 $('#forFriend').on({
        'init.bootstrapSwitch': function() {
        $('#forFriend').bootstrapSwitch("state", true);
}, 'switchChange.bootstrapSwitch': function(event, state) { // 按钮状态发生改变 } });

这样,就可以在加载完页面后对 switch 动态初始化值、并对switch组件状态切换事件进行响应。

想要对switch动态初始化,还需要一个条件,初始化switch状态时,不应该响应switch状态切换事件

上面的代码是做不到这一点的,为了能够做到,必须想一些办法,即使用代码改变swtch状态和用户改变switch状态有什么不同呢?答案是焦点。

当用户点击switch时,switch组件获得焦点; 相反的,如果使用代码改变swith组件时,焦点不能在switch上。通过这样判断方法就可以实现“随心所欲”的选择是否响应switch切换事件。

简单来写就是这样: 

$('#switch').on({
        'init.bootstrapSwitch': function() {
            $("#switch").bootstrapSwitch("state", state);// 初始化状态

        },
        'switchChange.bootstrapSwitch': function(event, state) {
            // 如果没有焦点,证明不是用户触发的, 不做任何处理
            if ($("#switch").is(":focus") == false) return;
            // 处理
        }
    });

我们可能还有一些需求,比如当用户开启switch时,弹出模态框,提示是否要开启,如果确认,则开启switch,否则不开启。

用户关闭模态框的方法有很多,可以选择右上角的关闭按钮、可以单击返回、可以点击确认,甚至是按下esc或者点击模态框以外的区域

模态框如图所示:

关闭方法很多,但除了点击确认外,其他的所有关闭模态框都认为拒绝 开启switch。 

代码如下:

$('#switch').on({
        'init.bootstrapSwitch': function() {

            // 确保一开始焦点不在switch上
            var state = true; // 从服务器获取按钮状态

            $("#switch").bootstrapSwitch("state", state);// 初始化状态

        },
        'switchChange.bootstrapSwitch': function(event, state) {
            // 如果没有焦点,证明不是用户触发的, 不做任何处理
            if ($("#switch").is(":focus") == false) return;

            if (state == true) { // 如果状态为 on, 需要开启模态框

                // 让其失去焦点,这时使用代码改变按钮状态就不会触发事件
                $("#switch").blur();

                // 防止模态框意外关闭,先设置按钮的状态为关闭
                $("#switch").bootstrapSwitch("state", false);

                // 弹出模态框
                $("#modal-switch").modal({backdrop: 'static', keyboard: false});

            } else { // 如果当前状态为off
                // 处理
            }
        }
    });

    // 单击了模态框中的确定按钮
    $('#modal-switch-confirm').click(function () {
        // 处理 ...

        // 处理成功改变 switch 状态
        $("#switch").bootstrapSwitch("state", true);
    });
原文地址:https://www.cnblogs.com/tanhehe/p/4263824.html