A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 石高攀 初级黑马   /  2019-4-25 13:44  /  687 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

根据ID获取
语法:document.getElementById(id)
作用:根据ID获取元素对象
参数:id值,区分大小写的字符串
返回值:元素对象 或 null
console.dir()  打印属性与方法;
注意:这个只能获取文档的元素,不能获取指定父元素的标签,即前面的元素只能是document,不能是其他的;
根据标签名获取元素
语法:document.getElementsByTagName('标签名') 或者 element.getElementsByTagName('标签名')
作用:根据标签名获取元素对象
参数:标签名
返回值:元素对象集合(伪数组,数组元素是元素对象)
<body>
    <ul>
        <li>知否知否,应是等你好久11</li>
        <li>知否知否,应是等你好久22</li>
        <li>知否知否,应是等你好久33</li>
        <li>知否知否,应是等你好久44</li>
        <li>知否知否,应是等你好久55</li>
    </ul>
    <ul id="nav">
        <li>生僻字</li>
        <li>生僻字</li>
        <li>生僻字</li>
        <li>生僻字</li>
        <li>生僻字</li>
    </ul>
    <script>
        // 1.返回的是 获取过来元素对象的集合 以伪数组的形式存储的
        var lis = document.getElementsByTagName('li');
        console.log(lis);
        console.log(lis[0]);
        // 2. 我们想要依次打印里面的元素对象我们可以采取遍历的方式
        for (var i = 0; i < lis.length; i++) {
            console.log(lis[i]);
        }
        // 3. element.getElementsByTagName()  可以得到这个元素里面的某些标签
        var nav = document.getElementById('nav'); // 这个获得nav 元素,记住,这个地方只能通过Id的方式或者querySelector()来获得父元素;
而用document.getElementsByTagName()和document.querySelectorAll()以及document.getElementsByClassName()获得的元素都是伪数组的形式,而不是单纯的父元素,所以没法用于指定的父元素获取子元素,但是也可以用数组的形式获得,比如
var  chars = document.getElementsByTagName('div');
var a = chars[0].getElementByClassName('box');
        var navLis = nav.getElementsByTagName('li');
        console.log(navLis);
    </script>
</body>

注意:getElementsByTagName()获取到是动态集合,即:当页面增加了标签,这个集合中也就增加了元素。如果没有获取到元素,返回的是一个空数组;
3. H5新增获取元素方式
document.getElementsByClassName();
document.querySelector();
document.querySelectorAll();

document.getElementsByClassName('类名');注意这里的类名直接写就可以了,不要加符号;
4 获取特殊元素(body,html)
document.body;
document.documentElement;

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马