glassysky111 2021-06-16 17:32 采纳率: 50%
浏览 70
已采纳

通过id调用的函数,如何在一个页面中运行多次?

用了一个js脚本,是通过id调用的,但是只能调用一次,如何修改能多次调用该脚本,或者有别的方法解决问题

脚本如下

(function () {
    var radioWrap = document.getElementById("radio_wrap"),
        li = radioWrap.getElementsByTagName("li");
    for (var i = 0; i < li.length; i++) {
        li[i].onclick = function () {
            for (var i = 0; i < li.length; i++) {
                li[i].className = "";
            }
            this.className = "checked";
        }
    }
})();

前端代码

  <div id="radio_wrap">
                        <span class="GoodsInformation_reight-dt" style="display:inline-block;font-weight:700;margin-top:5px">机身分类</span>
                        <ul >
                            <li class="c checked">
                                <input type="radio" id="radio_a_01" name="radio_a" />
                                <label for="radio_a_01"><span style="display:inline-block">海风青</span></label>
                                <i></i>
                            </li>
                            <li class="c">
                                <input type="radio" id="radio_a_02" name="radio_a" />
                                <label for="radio_a_02"><span style="display:inline-block">暗夜蓝</span></label>
                                <i></i>
                            </li>
                            <li class="c">
                                <input type="radio" id="radio_a_03" name="radio_a" />
                                <label for="radio_a_03"><span style="display:inline-block">绯玉红</span></label>
                                <i></i>
                            </li>
                        </ul>
                    </div>
                    <script src="../js/checkedborder.js"></script>
                    <div id="radio_wrap">
                        <span class="GoodsInformation_reight-dt" style="display:inline-block;font-weight:700;margin-top:5px">机身分类</span>
                        <ul >
                            <li class="c checked">
                                <input type="radio" id="radio_a_04" name="radio_a" />
                                <label for="radio_a_01"><span style="display:inline-block">海风青</span></label>
                                <i></i>
                            </li>
                            <li class="c">
                                <input type="radio" id="radio_a_05" name="radio_a" />
                                <label for="radio_a_02"><span style="display:inline-block">暗夜蓝</span></label>
                                <i></i>
                            </li>
                            <li class="c">
                                <input type="radio" id="radio_a_06" name="radio_a" />
                                <label for="radio_a_03"><span style="display:inline-block">绯玉红</span></label>
                                <i></i>
                            </li>
                        </ul>
                    </div>
                    <script src="../js/checkedborder.js"></script>
  • 写回答

3条回答 默认 最新

  • CSDN专家-showbo 2021-06-16 17:40
    关注

    id不能一样,一样需要使用属性选择器,不能用id选择器。你要分2组radio的话name不能一样,一样上下2组只能选择一个,只需要导入一次,在所有html代码最后导入一次就行。对你有帮助能点个采纳吗,谢谢~

    <div id="radio_wrap">
        <span class="GoodsInformation_reight-dt" style="display:inline-block;font-weight:700;margin-top:5px">机身分类</span>
        <ul>
            <li class="c checked">
                <input type="radio" id="radio_a_01" name="radio_a" />
                <label for="radio_a_01"><span style="display:inline-block">海风青</span></label>
                <i></i>
            </li>
            <li class="c">
                <input type="radio" id="radio_a_02" name="radio_a" />
                <label for="radio_a_02"><span style="display:inline-block">暗夜蓝</span></label>
                <i></i>
            </li>
            <li class="c">
                <input type="radio" id="radio_a_03" name="radio_a" />
                <label for="radio_a_03"><span style="display:inline-block">绯玉红</span></label>
                <i></i>
            </li>
        </ul>
    </div>
    <div id="radio_wrap">
        <span class="GoodsInformation_reight-dt" style="display:inline-block;font-weight:700;margin-top:5px">机身分类</span>
        <ul>
            <li class="c checked">
                <input type="radio" id="radio_a_04" name="radio_b" />
                <label for="radio_a_01"><span style="display:inline-block">海风青</span></label>
                <i></i>
            </li>
            <li class="c">
                <input type="radio" id="radio_a_05" name="radio_b" />
                <label for="radio_a_02"><span style="display:inline-block">暗夜蓝</span></label>
                <i></i>
            </li>
            <li class="c">
                <input type="radio" id="radio_a_06" name="radio_b" />
                <label for="radio_a_03"><span style="display:inline-block">绯玉红</span></label>
                <i></i>
            </li>
        </ul>
    </div>
    <script>
        (function () {
            var radioWrap = document.querySelectorAll("div[id=radio_wrap]");
            for (var Wrap of radioWrap) {
                li = Wrap.getElementsByTagName("li");
                for (var i = 0; i < li.length; i++) {
                    li[i].onclick = function () {
                        var li = this.parentNode.parentNode.getElementsByTagName("li");//通过dom关系获取各自的li
                        for (var i = 0; i < li.length; i++) {
                            li[i].className = "";
                        }
                        this.className = "checked";
                    }
                }
            }
        })();
    
    </script>
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 做个有关计算的小程序
  • ¥15 MPI读取tif文件无法正常给各进程分配路径
  • ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
  • ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下
  • ¥15 setInterval 页面闪烁,怎么解决
  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化