js实现类似与jquery的find方法

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>

    <div>
        <label>
            <input class='aui-radio' type='radio' name='authorizedCompanyList' value='1'>
            <span>测试1</span>
        </label>
    </div>
    <div>
        <label>
            <input class='aui-radio' type='radio' name='authorizedCompanyList' value='2'>
            <span>测试2</span>
        </label>
    </div>
    <button onclick="getSelectValue()">获取选中的值</button>
    <script>

        function getSelectValue() {
            const radios = document.getElementsByName('authorizedCompanyList');
            for (let i = 0; i < radios.length; i++) {
                if (radios[i].checked) {
                    // 输出选中的值  
                    console.log(radios[i].value);
                    //支持span .class #id等方式查找
                    var spans = findElements(radios[i].parentNode,"span")
                    console.log(spans[0].innerText);
                    
                }
            }
        }

        function findElements(element, selector) {
            var elements = [];
            var children = element.childNodes;

            for (var i = 0; i < children.length; i++) {
                var child = children[i];

                if (child.nodeType === 1 && child.matches(selector)) {
                    elements.push(child);
                }

                elements = elements.concat(findElements(child, selector));
            }

            return elements;
        }
    </script>
</body>

</html>

参考

https://blog.51cto.com/u_16213353/9429580

相关推荐
Qinana12 分钟前
🚀 用代码搭建「心情小窝」:一个极简情绪记录工具的实现 📝
前端·javascript
星眠15 分钟前
移动端下拉刷新的实现
javascript·面试
lifallen15 分钟前
Java stream 并发问题
java·开发语言·数据结构·算法
Emma歌小白16 分钟前
Vetur can't find tsconfig.json, jsconfig.json in /xxxx/xxxxxx.
javascript·后端
你的电影很有趣18 分钟前
lesson28:Python单例模式全解析:从基础实现到企业级最佳实践
开发语言·python
讨厌吃蛋黄酥20 分钟前
#Zustand:轻量级状态管理的革命,告别Context与Reducer的痛点!
前端·javascript·react.js
已读不回14327 分钟前
为什么Vue3使用Reflect而不是直接操作对象?
javascript·vue.js
Gazer_S1 小时前
【React Context API 优化与性能实践指南】
前端·javascript·react.js
颜挺锐1 小时前
Java 课程,每天解读一个简单Java之水仙花数
java·开发语言
w4ngzhen1 小时前
COME,轻量级自托管的站点评论系统套件
前端·javascript