>  기사  >  웹 프론트엔드  >  JS는 드롭다운 체크박스 효과를 구현합니다(코드 예)

JS는 드롭다운 체크박스 효과를 구현합니다(코드 예)

青灯夜游
青灯夜游원래의
2018-09-20 15:29:166313검색

이 장에서는 js를 사용하여 드롭다운 체크박스 효과를 구현하는 방법(코드 예제)을 설명합니다. 특정 참조 값이 있으므로 도움이 필요한 친구가 참고할 수 있기를 바랍니다. inction은 효과를 먼저 살펴 봅니다 :

JS는 드롭다운 체크박스 효과를 구현합니다(코드 예) 코드를 살펴 보겠습니다.

html 코드 :

<div>
        <select name="" id="lang1"></select>
        <ul id="ck1">
            <li>
                <label><input type="checkbox">HTML</label>
            </li>
            <li>
                <label><input type="checkbox">CSS</label>
            </li>
            <li>
                <label><input type="checkbox">JavaScript</label>
            </li>
            <li>
                <label><input type="checkbox">jQuery</label>
            </li>
            <li>
                <label><input type="checkbox">PHP</label>
            </li>
            <li>
                <label><input type="checkbox">MySQL</label>
            </li>
        </ul>
    </div>
    <hr><!--HTML结构不能变-->
    <div>
        <select name="" id="lang2"></select>
        <ul id="ck2">
            <li>
                <label><input type="checkbox">Java</label>
            </li>
            <li>
                <label><input type="checkbox">C#</label>
            </li>
            <li>
                <label><input type="checkbox">C++</label>
            </li>
            <li>
                <label><input type="checkbox">Pyhton</label>
            </li>
        </ul>
    </div>
    <input type="button" onclick="console.log({&#39;tag1&#39;:tag1,&#39;tag2&#39;:tag2,})" value="查看字段">
e
css 코드 :

div {
    display: inline-block;
}

select {
    min-width: 200px;
    height: 25px;
    border: 1px solid #000;
}

ul {
    display: none;
    list-style: none;
    margin: 0;
    padding: 0;
    border: 1px solid #000;
}

label {
    display: block;
    padding: 2px 10px;
    white-space: nowrap;
}

ul li:hover {
    background-color: #aabbcc;
}
ajavaScript 코드 :

R
/**
     * [dropDownCk 下拉复选框]
     * @param  {[String]} boxId    [父级元素id]
     * @param  {[String]} selectId [下拉选id]
     * @param  {[String]} hiddenId [隐藏区域id]
     * @return {[Array]}          [description]
     */
    function dropDownCk(selectId,hiddenId) {

        var boxId = "#" + boxId,
            selectId = "#" + selectId,
            hiddenId = "#" + hiddenId;
        
        $(hiddenId).mouseleave(function(){ // 鼠标离开隐藏复选区域
            
            $(this).hide();
        
        });
        
        $(selectId).click(function() { // 切换显示与隐藏

            $(hiddenId).toggle();

        });

        var tagArr = []; // 接收复选字段数组

        $(selectId).html("<option checked=&#39;true&#39; style=&#39;display:none;&#39;>" + "请选择项目" + "</option>");

        $(hiddenId + &#39; label&#39;).find(&#39;input&#39;).click(function() { // 点击向数组添加元素

            if ($(this).is(&#39;:checked&#39;)) {

                tagArr.push($(this).parent().text());

                $(selectId).html("<option checked=&#39;true&#39; style=&#39;display:none;&#39;>" + tagArr.join(",") + "</option>");

            } else {

                tagArr.splice(tagArr.indexOf($(this).parent().text()), 1); // 删除对应元素

                if (tagArr.length == 0) {

                    $(selectId).html("<option checked=&#39;true&#39; style=&#39;display:none;&#39;>" + "请选择项目" + "</option>");

                } else {

                    $(selectId).html("<option checked=&#39;true&#39; style=&#39;display:none;&#39;>" + tagArr.join(",") + "</option>");

                }

            }

        });

        return tagArr;
    }

    var tag1 = dropDownCk("lang1","ck1");
    var tag2 = dropDownCk("lang2","ck2")

NOTE : 언제 많은 옵션이 있습니다. 배열을 정의하고 HTML에 삽입하여 드롭다운 옵션을 구현할 수 있습니다. 3단계 연결의 작성 방법을 참조할 수 있습니다:
JavaScript의 3단계 연결 예제

로 플레이해 보세요.

위 내용은 JS는 드롭다운 체크박스 효과를 구현합니다(코드 예)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.