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

相关推荐
CPETW2 分钟前
同旺科技 USB TO SPI / I2C适配器(专业版)--EEPROM读写——C
c语言·开发语言·科技·stm32·单片机·嵌入式硬件·电子
代码中の快捷键10 分钟前
如何实现一个登录功能?
java·开发语言
虾球xz12 分钟前
CppCon 2015 学习:C++ devirtualization in clang
开发语言·c++·学习
我不吃饼干39 分钟前
我给掘金写了一个给用户加标签的功能
前端·javascript·cursor
看到我,请让我去学习42 分钟前
C++核心编程(动态类型转换,STL,Lanmda)
c语言·开发语言·c++·stl
conkl1 小时前
Apache网页优化实战指南 - 让网站加载速度提升
linux·运维·服务器·开发语言·阿里云·apache
onlooker66661 小时前
Go语言底层(五): 深入浅出Go语言的ants协程池
开发语言·后端·golang
刚子编程1 小时前
C# WinForms 实现打印监听组件
开发语言·c#·winform·打印监听组件
泽02021 小时前
C++之模板进阶
开发语言·c++·算法
武子康1 小时前
Java-46 深入浅出 Tomcat 核心架构 Catalina 容器全解析 启动流程 线程机制
java·开发语言·spring boot·后端·spring·架构·tomcat