zoukankan      html  css  js  c++  java
  • 前端入门笔js篇之DOM(1)

    写在前面

    APT

    API(应用程序编程接口),是一些预先定义的函数。

    webAPI

    webAPI主要针对于浏览器提供的接口,主要准对于浏览器最交互效果。

    一.DOM简介

    1.DOM

    文本对象模型(Document Object Model),是W3C推荐的处理可拓展标记语言(HTML或者XML)的标准编程接口。通过一系列的DOM接口可以改变网页的内容,结构和样式。

    2.DOM树

    文档 : 一个页面就是一个文档,DOM中使用document表示

    元素: 页面中所有的标签都是元素,DOM使用element表示

    节点: 网页中所有的内容都是节点(标签,属性,文本,注释等),DOM中用node表示

    二.获取元素

    1.根据ID获取

    document.getElementById('id')

    注:

    id是有大小写区分字符串
    返回值是元素对象

    demo

    <div id="time"> 2020-3-20</div>
    <script>
        var times = document.getElementById('time');  //获取元素对象
        console.log(times);      //输出元素对象
        console.dir(times);    //dir输出元素对象
    </script>
    

    2.根据元素名获取

    document.getElementsByTagName('元素名')

    注:

    元素名是区分大小写的字符串

    返回的是元素对象的集合,以伪数组的形式返回元素

    demo——返回文档里面所有的li

    <ul>
        <li>知否知否,等你好久1</li>
        <li>知否知否,等你好久2</li>
        <li>知否知否,等你好久3</li>
    </ul>
    <ul id="nav">
        <li>111</li>
        <li>222</li>
        <li>333</li>
        <li>444</li>
    </ul>
    <script>
        var list = document.getElementsByTagName('li');
        console.log(list);      //返回的是元素对象的集合,以伪数组的形式返回元素
        console.log(list[0]);
        for(var i=0; i<list.length;i++){
            console.log(list[i]);
        }
    </script>
    

    demo——返回文档里某一部分li

    <body>
        <ul>
            <li>知否知否,等你好久1</li>
            <li>知否知否,等你好久2</li>
            <li>知否知否,等你好久3</li>
        </ul>
        <ul id="nav">
            <li>111</li>
            <li>222</li>
            <li>333</li>
            <li>444</li>
        </ul>
        <script>
            //返回的是nav里面li
            var  nav = document.getElementById('nav').getElementsByTagName('li');
            console.log(nav);
            for (var i = 0; i <= nav.length; i++) {
                console.log(nav[i]);
            }
        </script>
    </body>
    

    3.HTML5新增

    (1)方法一

    getElementsByClassName('class_name')
    

    根据类名获的某些元素对象集合

    <div class="box">盒子1</div>
    <div class="box">盒子2</div>
    <div id='nav'>
        <ul>
            <li>首页</li>
            <li>产品</li>
        </ul>
    </div>
    <script>
        var boxs = document.getElementsByClassName('box'); //选中两个带有box属性的div
        console.log(boxs);               
    </script>
    

    (2)方法二

    querySelector('selectors')
    

    返回的是指定选择器的第一个元素对象

    'selectors'必须是有效的CSS选择器字符串,比如说:ID选择器(’#ID_name‘),类选择器('.class_name'),标签选择器('div');如果不是,则引发SYNTAX_ERR异常。

    <body>
        <div class='nav'>
            <ul>
                <li>li1</li>
                <li>li2</li>
            </ul>
        </div>
        <script>  
            var li = document.querySelector("div.nav").querySelector('li')//选中第一个li
            console.log(li)    
        </script>
    </body>>
    

    (3)方法三

    querySelectorAll ( )
    

    返回的是指定选择器的所有元素的集合。

    <div class="box">盒子1</div>
    <div class="box">盒子2</div>
    <div id='nav'>
        <ul>
            <li>首页</li>
            <li>产品</li>
        </ul>
    </div>
    <script>
        var allBox = document.querySelectorAll('.box');        //获取两个div
        console.log(allBox);
        var lis = document.querySelectorAll('li');  获取全部的li
        console.log(lis);
    </script>
    

    4.获取特殊元素

    body和html

    <script>
        //获取body
        var bodyEle = document.body;
        console.log(bodyEle);
        //获取html
        var htmlEle = document.documentElement;
        console.log(htmlEle);
        console.dir(htmlEle);
    </script>
    

    三.事件基础

    1.概念

    事件是可以被js侦测到的行为。可以理解触发---响应机制

    事件的三部分:

    事件源 :被触发的对象
    事件类型 : 如何触发事件(鼠标点击,鼠标经过,键盘按下等)
    事件处理程序 : 通过函数赋值来完成

    <button id="btn">唐伯虎</button>
    <script>
            //1.事件源 
            var btn = document.getElementById('btn');
            //2.事件类型  (onclick)
            //3.事件处理程序
            btn.onclick = function () {
                alert('点秋香') ;
            }
    </script>
    

    2.执行事件的过程

    1.获取事件源 ——> 2.注册事件(绑定事件)——>3.添加事件处理程序

    <button id="btn">唐伯虎</button>
    <script>
            //1.获取事件源
            var btn = document.getElementById('btn');
            //2.注册事件(绑定事件)
             //btn.onclick
            //3.添加事件处理程序
            btn.onclick = function () {
                alert('点秋香') ;
            }
    </script>
    

    三.操作元素

    1.更改元素内容

    (1)element.innerText

    从起始位置到终止位置的内容,但是它去除html标签,同时空格和换行也会去掉。(换句话说就是,不识别html标签)

    (2)element.innerHTML

    从起始位置到终止位置的内容,但是它不去除html标签,空格和换行也会保留。(换句话说就是,识别html标签)

    <body>
        <button>获取当前时间</button>
        <div>时间</div>
        <p></p>
        <script>
            //获取事件源
            var btn = document.querySelector('button');
            var time = document.querySelector('div');
            //获取系统时间
            function getDate() {
                var date = new Date();
                var year = date.getFullYear();
                var month = date.getMonth();
                var dates = date.getDate();
                var day = date.getDay();
                var arr = ['星期天', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六']
                var arr_1 = arr[day];
                 return '今天是' + year + '年' + month + '月' + dates + '日' + arr_1 ;
            }
            //绑定事件
            btn.onclick = function(){
                time.innerText = getDate();
            }
          //也可以不绑定点击事件,不用点击直接自动获取当前时间
           var p = document.querySelector('p');
            p.innerText = getDate();
        </script>
    </body>
    

    (3)异同

    不同点:

    element.innerText——它不识别html标签,不保留换行和空格

    element.innerHTML——会识别html标签,保留换行和空格

    demo1

    <body>
        <p>ppppp</p>
        <div>divdivdivdivd</div>
        <script>
            var p = document.querySelector('p');
            var div = document.querySelector('div');
            p.innerText = '<Strong>不加粗</Strong>'; //不会识别标签
            div.innerHTML = '<Strong>会加粗</Strong>';//会识别标签
        </script>
    </body>
    

    相同点:

    都支持读写

    demo2

    <body>
        <p>p ppp</p>
        <script>
            var p = document.querySelector('p');
            var div = document.querySelector('div');
            console.log(p.innerText);        //读
            console.log(p.innerHTML);         //demo1的操作是写
        </script>
    </body>
    

    2.更改元素属性

    更改src alt title等属性

    demo1——点击不同的按钮,显示不同的图面和提示信息

    <body>
        <button id="1">1</button>
        <button id="2">1</button>
        <br>
        <img src="1.jpg" alt='哦豁' title="我是1">
        <script>
            //获取事件源
            var bnt1 = document.getElementById('1');
            var bnt2 = document.getElementById('2');
            var img = document.querySelector('img');
            //绑定事件 处理程序
            bnt1.onclick = function() {
                img.src = '1.jpg';
                img.title = '我是1';
                img.alt = '哦豁1'
            }
            bnt2.onclick = function(){
                img.src = '2.jpg';
                img.title = '我是2';
                img.alt = '哦豁2';
            }
        </script>
    </body>
    

    demo2——根据系统不同的时间显示不同的图片和文字

    <body>
        <img src="#" alt="早上好">
        <div>早上好</div>
        <script>
            //取源
        var img = document.querySelector('img');
        var div = document.querySelector('div');
        //获取时间
        var date = new Date();
        var time = date.getHours()
        //判断时间,进行对应更改
        if (time < 12){
            img.src='m.jpg';
            div.innerHTML = '早上好';
        }else if (time < 18){
            img.src='g.jpg';
            div.innerHTML = '下上好';
        }else {
            img.src='n.jpg';
            div.innerHTML = '晚上好';
        }
        </script>
    </body>
    

    3.表单元素属性操作(type,value)

    表单里面的文字内容,不能通过innerText和innerHTML来修改,要通过value来修改

    表单类型通过修改type

    demo——button点击过一次之后就禁用按钮

    <button>按钮</button>
    <input type="text" value="输入内容">
    <script>
        var btn = document.querySelector('button');
        var tab = document.querySelector('input');
        btn.onclick = function(){
            tab.value = '被点击了';
            //点击过一次之后就禁用按钮
            this.disabled = true;
        }
    </script>
    

    demo——仿密码登录框

    <div class="box">
        <label for="">
             <img src="images/close.png" alt="" id="eye">
        </label>
        <input type="password" name="" id="pwd">
    </div>
    <script>
            // 1. 获取元素
            var eye = document.getElementById('eye');
            var pwd = document.getElementById('pwd');
            // 2. 注册事件 处理程序
            var flag = 0;  //当为0的时候为text,为1时为password
            eye.onclick = function() {
                // 点击一次之后, flag 一定要变化
                if (flag == 0) {
                    pwd.type = 'text';
                    eye.src = 'images/open.png';
                    flag = 1; // 赋值操作
                } else {
                    pwd.type = 'password';
                    eye.src = 'images/close.png';
                    flag = 0;
                }
            }
    </script>
    

    4.样式属性操作

    (1)行内样式操作

    element.style.样式

    demo

    <style>
       div {
            200px;
           height: 200px;
           background-color: pink;
       }
    </style>
    
    <body>
        <div></div>
        <script>
         // 1. 获取元素
            var div = document.querySelector('div');
        // 2. 注册事件 处理程序
            div.onclick = function() {
                // div.style里面的属性 采取驼峰命名法 
                 this.style.backgroundColor = 'purple';
                 this.style.width = '250px';
            }
        </script>
    </body>
    

    注释:

    1.js修改style样式操作,产生的是行内样式,权重较高
    2.在css样式较少的情况下,使用element.style.样式

    (2)类名样式

    element.className

    <style>
        .first {
             100px;
            height: 100px;
            background-color: pink;
        }
        .change {
            background-color: purple;
            color: #fff;
            font-size: 25px;
            margin-top: 100px;
        }
    </style>
    
    <body>
        <div class="first">文本</div>
        <script>
            var test = document.querySelector('div');
            test.onclick = function() {
                // 如果想要保留原先的类名,我们可以用多类名选择器
                this.className = 'first change';
            }
        </script>
    </body>
    

    注:

    element.clsssName适用于复杂的css样式

    5.排他思想

    首先先排除其他人,然后才设置自己的样式 这种排除其他人的思想我们成为排他思想。

    <body>
        <button>按钮1</button>
        <button>按钮2</button>
        <button>按钮3</button>
        <button>按钮4</button>
        <button>按钮5</button>
        <script>
            // 1. 获取所有按钮元素
            var btns = document.getElementsByTagName('button');
            // btns得到的是伪数组,获取里面的每一个元素 btns[i]
            for (var i = 0; i < btns.length; i++) {
                btns[i].onclick = function() {
                    // (1) 我们先把所有的按钮背景颜色去掉 
                    for (var i = 0; i < btns.length; i++) {
                        btns[i].style.backgroundColor = '';
                    }
                    // (2)  留下要设置的样式
                    this.style.backgroundColor = 'pink';
                }
            }
        </script>
    </body>
    

    demo —— 鼠标经过表格行变色案例,鼠标经过行变色,鼠标离开恢复

    <style>
            table {
                 800px;
                margin: 100px auto;
                text-align: center;
                border-collapse: collapse;
                font-size: 14px;
            }
            
            thead tr {
                height: 30px;
                background-color: skyblue;
            }
            
            tbody tr {
                height: 30px;
            }
            
            tbody td {
                border-bottom: 1px solid #d7d7d7;
                font-size: 12px;
                color: blue;
            }
            
            .bg {
                background-color: pink;
            }
     </style>
    <body>
        <table>
            <thead>
                <tr>
                    <th>代码</th>
                    <th>名称</th>
                    <th>最新公布净值</th>
                    <th>累计净值</th>
                    <th>前单位净值</th>
                    <th>净值增长率</th>
                </tr>
            </thead>
            <tbody>
                <tr>
                    <td>003526</td>
                    <td>农银金穗3个月定期开放债券</td>
                    <td>1.075</td>
                    <td>1.079</td>
                    <td>1.074</td>
                    <td>+0.047%</td>
                </tr>
                <tr>
                    <td>003526</td>
                    <td>农银金穗3个月定期开放债券</td>
                    <td>1.075</td>
                    <td>1.079</td>
                    <td>1.074</td>
                    <td>+0.047%</td>
                </tr>
                <tr>
                    <td>003526</td>
                    <td>农银金穗3个月定期开放债券</td>
                    <td>1.075</td>
                    <td>1.079</td>
                    <td>1.074</td>
                    <td>+0.047%</td>
                </tr>
                <tr>
                    <td>003526</td>
                    <td>农银金穗3个月定期开放债券</td>
                    <td>1.075</td>
                    <td>1.079</td>
                    <td>1.074</td>
                    <td>+0.047%</td>
                </tr>
                <tr>
                    <td>003526</td>
                    <td>农银金穗3个月定期开放债券</td>
                    <td>1.075</td>
                    <td>1.079</td>
                    <td>1.074</td>
                    <td>+0.047%</td>
                </tr>
                <tr>
                    <td>003526</td>
                    <td>农银金穗3个月定期开放债券</td>
                    <td>1.075</td>
                    <td>1.079</td>
                    <td>1.074</td>
                    <td>+0.047%</td>
                </tr>
            </tbody>
        </table>
        <script>
            // 1.获取元素 获取的是 tbody 里面所有的行
            var trs = document.querySelector('tbody').querySelectorAll('tr');
            // 2. 利用循环绑定注册事件
            for (var i = 0; i < trs.length; i++) {
                // 3. 鼠标经过事件 onmouseover
                trs[i].onmouseover = function() {
                        // console.log(11);
                        this.className = 'bg';
                    }
                    // 4. 鼠标离开事件 onmouseout
                trs[i].onmouseout = function() {
                    this.className = '';
                }
            }
        </script>
    </body>
    

    demo —— 全选按钮

    <style>
            * {
                padding: 0;
                margin: 0;
            }
            
            .wrap {
                 300px;
                margin: 100px auto 0;
            }
            
            table {
                border-collapse: collapse;
                border-spacing: 0;
                border: 1px solid #c0c0c0;
                 300px;
            }
            
            th,
            td {
                border: 1px solid #d0d0d0;
                color: #404060;
                padding: 10px;
            }
            
            th {
                background-color: #09c;
                font: bold 16px "微软雅黑";
                color: #fff;
            }
            
            td {
                font: 14px "微软雅黑";
            }
            
            tbody tr {
                background-color: #f0f0f0;
            }
            
            tbody tr:hover {
                cursor: pointer;
                background-color: #fafafa;
            }
     </style>
    <body>
        <div class="wrap">
            <table>
                <thead>
                    <tr>
                        <th>
                            <input type="checkbox" id="j_cbAll" />
                        </th>
                        <th>商品</th>
                        <th>价钱</th>
                    </tr>
                </thead>
                <tbody id="j_tb">
                    <tr>
                        <td>
                            <input type="checkbox" />
                        </td>
                        <td>iPhone8</td>
                        <td>8000</td>
                    </tr>
                    <tr>
                        <td>
                            <input type="checkbox" />
                        </td>
                        <td>iPad Pro</td>
                        <td>5000</td>
                    </tr>
                    <tr>
                        <td>
                            <input type="checkbox" />
                        </td>
                        <td>iPad Air</td>
                        <td>2000</td>
                    </tr>
                    <tr>
                        <td>
                            <input type="checkbox" />
                        </td>
                        <td>Apple Watch</td>
                        <td>2000</td>
                    </tr>
                </tbody>
            </table>
        </div>
        <script>
            // 1. 全选和取消全选做法:  让下面所有复选框的checked属性(选中状态) 跟随 全选按钮即可
            // 获取元素
            var j_cbAll = document.getElementById('j_cbAll'); // 全选按钮
            var j_tbs = document.getElementById('j_tb').getElementsByTagName('input'); // 下面所有的复选框
            // 注册事件
            j_cbAll.onclick = function() {
                    // this.checked 它可以得到当前复选框的选中状态如果是true 就是选中,如果是false 就是未选中
                    console.log(this.checked);
                    for (var i = 0; i < j_tbs.length; i++) {
                        j_tbs[i].checked = this.checked;
                    }
                }
                // 2. 下面复选框需要全部选中, 上面全选才能选中做法: 给下面所有复选框绑定点击事件,每次点击,都要循环查看下面所有的复选框是否有没选中的,如果有一个没选中的, 上面全选就不选中。
            for (var i = 0; i < j_tbs.length; i++) {
                j_tbs[i].onclick = function() {
                    // flag 控制全选按钮是否选中
                    var flag = true;
                    // 每次点击下面的复选框都要循环检查者4个小按钮是否全被选中
                    for (var i = 0; i < j_tbs.length; i++) {
                        if (!j_tbs[i].checked) {
                            flag = false;
                            break; // 退出for循环 这样可以提高执行效率 因为只要有一个没有选中,剩下的就无需循环判断了
                        }
                    }
                    j_cbAll.checked = flag;
                }
            }
       </script>
    </body>
    

    6.自定义属性操作

    (1)获取属性值

    //方法一
    获取内置属性值(元素本身自带的属性)
    element.属性
    //方法二
    主要获得程序员自定义的属性
    element.getAttribute('属性')
    

    (2)设置属性值

    //方法一
    element.属性 = '值'
    //方法二
    element.setAttribute( ) //主要用于自定义属性
    

    demo

    <div id="demo" index="1" class="nav"> </div>
        <script>
            var divs = document.querySelector('div');
            //获取属性值,方法一
            console.log(divs.className);
            //获取属性值,方法二
            console.log(divs.getAttribute('class'));
            //更改属性值方法一
            divs.id = 'text';
            console.log(divs.id);
            //更改属性值方法二
            divs.setAttribute('index',2);
            console.log(divs.getAttribute('index'));
        </script>
    

    (3)移除属性

    divs.removeAttribute('属性名')
    

    7.综合案例

    Tab栏切换

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
        <style>
            * {
                margin: 0;
                padding: 0;
            }
            
            li {
                list-style-type: none;
            }
            
            .tab {
                 978px;
                margin: 100px auto;
            }
            
            .tab_list {
                height: 39px;
                border: 1px solid #ccc;
                background-color: #f1f1f1;
            }
            
            .tab_list li {
                float: left;
                height: 39px;
                line-height: 39px;
                padding: 0 20px;
                text-align: center;
                cursor: pointer;
            }
            
            .tab_list .current {
                background-color: #87CEFA;
                color: #fff;
            }
            
            .item_info {
                padding: 20px 0 0 20px;
            }
            
            .item {
                display: none;
            }
        </style>
    </head>
    
    <body>
        <div class="tab">
            <div class="tab_list">
                <ul>
                    <li class="current">红玫瑰</li>
                    <li>紫玫瑰</li>
                    <li>黑玫瑰</li>
                    <li> 绿玫瑰</li>
                    <li>香槟玫瑰</li>
                </ul>
            </div>
            <div class="tab_con">
                <div class="item" style="display: block;">
                    送花对象:朋友、恋人、爱人 </br>
                    花语:热恋、希望与你泛起激情的爱
                </div>
                <div class="item">
                    送花对象:爱人、恋人 </br>
                    花语:成熟的爱、你的幸福比我的重要。
                </div>
                <div class="item">
    
                    送花对象:朋友、情人 </br>
                    花语:温柔真心,独一无二;你是恶魔,且为我所有。
                </div>
                <div class="item">
                    送花对象:朋友、爱人
                    </br/> 花语:纯真简朴、青春长驻、永不老去的爱情。 永不老去的爱情,绿玫瑰的花语简单而伟大。
                </div>
                <div class="item">
    
                    送花对象:朋友、恋人</br>
                    花语:我只钟情你一个。
    
                </div>
    
            </div>
        </div>
        <script>
            // 获取元素
            var tab_list = document.querySelector('.tab_list');
            var lis = tab_list.querySelectorAll('li');
            var items = document.querySelectorAll('.item');
            // for循环绑定点击事件
            for (var i = 0; i < lis.length; i++) {
                // 开始给5个小li 设置索引号 
                lis[i].setAttribute('index', i);
                lis[i].onclick = function() {
                    // 1. tab栏模块,利用排他思想,设置当前点击的颜色为淡蓝色。其他不变
                    for (var i = 0; i < lis.length; i++) {
                        lis[i].className = '';
                    }
                    this.className = 'current';
                    // 2. 显示内容模块
                    var index = this.getAttribute('index');
                    console.log(index);
                    //让其余的item 这些div 隐藏
                    for (var i = 0; i < items.length; i++) {
                        items[i].style.display = 'none';
                    }
                    // 对应的item 显示出来
                    items[index].style.display = 'block';
                }
            }
        </script>
    </body>
    
    </html>
    

  • 相关阅读:
    移动web技能总结
    canvas绘图基础
    如何自定义滚动条?
    学习笔记-AngularJs(十)
    学习笔记-AngularJs(九)
    硬盘杀手!Windows版Redis疯狂占用C盘空间【转】
    64位win10系统无法安装.Net framework3.5的两种解决方法【转】
    分享一个电子书地址
    阿里、腾讯、百度、华为、京东、搜狗和滴滴最新面试题汇集【转】
    jQuery时间轴
  • 原文地址:https://www.cnblogs.com/lc-snail/p/13173384.html
Copyright © 2011-2022 走看看