溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

layui如何實(shí)現(xiàn)監(jiān)聽多個(gè)radio事件

發(fā)布時(shí)間:2020-06-17 11:52:07 來源:億速云 閱讀:735 作者:鴿子 欄目:web開發(fā)

需求如下圖:想要選中單選框3,是單選框3下的復(fù)選框全選

layui如何實(shí)現(xiàn)監(jiān)聽多個(gè)radio事件

如果 面板信息 不多的話,可以給每個(gè)單選框3添加一個(gè)固定的監(jiān)聽事件

但是實(shí)際項(xiàng)目中,不僅僅只有兩個(gè),會(huì)有幾十個(gè),這時(shí)總不能綁定一個(gè)lay-filter,添加一個(gè)form.on('radio(filter)')事件吧

所以在此寫了一個(gè)通用的監(jiān)聽多個(gè)radio的方法:

// 選取“單選框3”,“單選框3”下的所有內(nèi)容全選
        var flagID = document.querySelectorAll("input[title='單選框3']");
        var aFlagID = new Array();
        for (var j = 0; j < flagID.length; j++) {
            aFlagID.push(flagID[j].id);
        }
        // 監(jiān)聽所有title為“單選框3”的radio
        // 注意:此時(shí)title為“單選框3”的radio的id和lay-filter需要設(shè)為一致!?。?!
        for (var i = 0; i < aFlagID.length; i++) {
             form.on('radio('+aFlagID[i]+')', function(data) {
                $(data.elem).next().next().children("input").addClass(""+aFlagID[i]+"_other");
                $("."+aFlagID[i]+"_other").attr("checked", "checked");
                $("."+aFlagID[i]+"_other + div").addClass('layui-form-checked');
                element.init();
            });
        }

此處,是通過id來獲取每個(gè)radio的lay-filter,將radio的id與lay-filter設(shè)置成一樣的;

$(data.elem)就是當(dāng)前監(jiān)聽的DOM元素;這里要注意看瀏覽器已經(jīng)渲染成功的頁面;

此時(shí)選中的是input元素,即為單選框3,但是由于layui將input美化掉了,所以此input沒有顯示;

layui如何實(shí)現(xiàn)監(jiān)聽多個(gè)radio事件注意看下圖:此時(shí)input下一個(gè)元素才是我們看到的“單選框3”

layui如何實(shí)現(xiàn)監(jiān)聽多個(gè)radio事件

在選取元素的時(shí)候一定要找準(zhǔn)元素!

此方法有以下局限性:

1.需要手動(dòng)給每個(gè)“單選框3”設(shè)置id和lay-filter;

2.“單選框3”的id和lay-filter需要一致;

3.獲取元素時(shí)是通過jQuery方法尋找元素;

4.需要按照不同的頁面布局變更尋找元素的方式。

以上就是layui監(jiān)聽多個(gè)radio事件的方法的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注億速云其它相關(guān)文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI