JavaScript- 操作元素案例

操作元素

排他思想案例

1. 背景换肤案例

这个案例练习的是给一组元素注册事件
给4个小图片利用循环注册点击事件
当点击了这个图片,让页面背景改为当前的图片
核心算法: 把当前图片的src 路径取过来,给 body 做为背景即可
在这里插入图片描述

    <style>
        * {
            margin: 0;
            padding: 0;
        }
    
        body {
            background: url(img/今天也要加油鸭.jpg) no-repeat center top;
        }
    
        li {
            list-style: none;
        }
    
        .yemian {
            overflow: hidden;
            margin: 100px auto;
            background-color: #fff;
            width: 40px;
            padding-top: 3px;
        }
    
        .yemian li {
            float: left;
            margin: 0 1px;
            cursor: pointer;
        }
    
        .yemian img {
            width: 100px;
        }
    </style>
</head>
<body>
    <ul class="yemian">
        <li><img src="./img/今天不想加油鸭.jpg"></li>
        <li><img src="./img/今天也要加油鸭.jpg"></li>
        <li><img src="./img/特警.jpg"></li>
        <li><img src="./img/鸭子.jpg"></li>
    </ul>
    <script>
        // 1.获取元素
        var imgs = document.querySelector('.yemian').querySelectorAll('img')
        // 2.循环注册事件
        for (var i = 0; i < imgs.length; i++) {
            imgs[i].onclick = function () {
                document.body.style.backgroundImage = 'url(' + this.src + ')'
            }

        }
    </script>
</body>

2. 表格隔行变色案例

用到新的鼠标事件 鼠标经过 onmouseover 鼠标离开 onmouseout
核心思路:鼠标经过 tr 行,当前的行变背景颜色, 鼠标离开去掉当前的背景颜色
注意: 第一行(thead里面的行)不需要变换颜色,因此我们获取的是 tbody 里面的行
在这里插入图片描述

<body>
    <style>
        table {
            width: 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: gray;
        }
    </style>
    <table>
        <thead>
            <tr>
                <th>代码</th>
                <th>名称</th>
                <th>最新公布净值</th>
                <th>累计净值</th>
                <th>前单位净值</th>
                <th>净值增长率</th>
            </tr>
        </thead>
        <tbody>
            <tr>
                <th>003526</th>
                <th>农银金穗3个月定期开放债券</th>
                <th>1.075</th>
                <th>1.079</th>
                <th>1.074</th>
                <th>+0.047%</th>
            </tr>
            <tr>
                <th>270047</th>
                <th>广发理财</th>
                <th>0.903</th>
                <th>3.386</th>
                <th>0.000</th>
                <th>0.000%</th>
            </tr>
            <tr>
                <th>163417</th>
                <th>兴全合宜</th>
                <th>0.860</th>
                <th>0.860</th>
                <th>0.863</th>
                <th>-0.382%</th>
            </tr>
            <tr>
                <th>003929</th>
                <th>中银证券</th>
                <th>1.034</th>
                <th>1.088</th>
                <th>1.034</th>
                <th>+0.077%</th>
            </tr>
        </tbody>
    </table>
    <script>
        // 1.获取元素:tbody里面所有的行
        var trs = document.querySelector('tbody').querySelectorAll('tr')
        // 2. 利用循环绑定注册时间
        for (var i = 0; i < trs.length; i++) {
            // 3.鼠标经过事件 
            trs[i].onmouseover = function () {
                this.className = 'bg'
            }
            // 4. 鼠标离开事件
            trs[i].onmouseout = function () {
                this.className = ''
            }
        }
    </script>
</body>

3. 表单全选取消案例

业务需求

  • 点击上面全选复选框,下面所有的复选框都选中(全选)
  • 再次点击全选复选框,下面所有的复选框都不中选(取消全选)
  • 如果下面复选框全部选中,上面全选按钮就自动选中
  • 如果下面复选框有一个没有选中,上面全选按钮就不选中
  • 所有复选框一开始默认都没选中状态

分析

  • 全选和取消全选做法: 让下面所有复选框的checked属性(选中状态) 跟随 全选按钮即可
  • 下面复选框需要全部选中, 上面全选才能选中做法: 给下面所有复选框绑定点击事件,每次点击,都要循环查看下面所有的复选框是否有没选中的,如果有一个没选中的, 上面全选就不选中。
  • 可以设置一个变量,来控制全选是否选中
    在这里插入图片描述
    在这里插入图片描述
<body>
    <style>
        * {
            padding: 0;
            margin: 0;
        }

        .wrap {
            width: 300px;
            margin: 100px auto 0;
        }

        table {
            border-collapse: collapse;
            border-spacing: 0;
            border: 1px solid #c0c0c0;
            width: 300px;
        }

        th,
        td {
            border: 1px solid #d0d0d0;
            color: #404060;
            padding: 10px;
        }

        th {
            background-color: #09c;
            font: bold 16px '仿宋';
            color: #fff;
        }

        td {
            font: 14px '仿宋';
        }

        tbody th {
            background-color: #f0f0f0;
            color: #404060;
        }

        tbody tr:hover {
            cursor: pointer;
            background-color: #fafafa;
        }
    </style>
    <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>
                    <th>
                        <input type="checkbox">
                    </th>
                    <th>荣耀20</th>
                    <th>2799</th>
                </tr>
                <tr>
                    <th>
                        <input type="checkbox">
                    </th>
                    <th>小米</th>
                    <th>2699</th>
                </tr>
                <tr>
                    <th>
                        <input type="checkbox">
                    </th>
                    <th>oppo</th>
                    <th>2699</th>
                </tr>
                <tr>
                    <th>
                        <input type="checkbox">
                    </th>
                    <th>vivo</th>
                    <th>2699</th>
                </tr>
            </tbody>
        </table>
    </div>
    <script>
        // 全选和取消全选
        // 1. 获取元素
        var j_cbAll = document.getElementById('j_cbAll')   //全选按钮
        var j_tbs = document.getElementById('j_tb').getElementsByTagName('input')   //下面所有的复选框
        // 注册事件
        j_cbAll.onclick = function () {
            // this.checked可以得到当前复选框的选中状态,true则为选中
            console.log(this.checked)
            for (var i = 0; i < j_tbs.length; i++) {
                j_tbs[i].checked = this.checked   //!!!关键点,一定要搞懂
            }
        }
        // 下面复选按钮影响上面的全选按钮
        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++) {   //该for循环包含在上一个function函数中,属于不同的作用域,两个i不受影响
                    if (!j_tbs[i].checked) {   //对该按钮取反则表示该按钮没有被选中。默认全部都是未选中,所以第一次选中得到的是true
                        //j_cbAll.checked = false    //因为存在按钮没有被选中,所以让全选按钮改成flase
                        flag = false
                        break   //退出for循环,提高执行效率。只要有一个没选中就不用再继续判断,就无意义了
                    }
                }
                j_cbAll.checked = flag
            }
        }
    </script>
</body>

自定义属性案例

1.tab栏切换(重点案例)

当鼠标点击上面相应的选项卡(tab),下面的内容跟随变化
在这里插入图片描述
在这里插入图片描述

案例分析:

  • Tab栏切换有2个大的模块
  • 上面的模块选项卡,点击某一个,当前这一个底色会是红色,其余不变(排他思想) 修改类名的方式
  • 下面的模块内容,会跟随上面的选项卡变化。所以下面模块变化写到点击事件里面。
  • 规律:下面的模块显示内容和上面的选项卡一一对应,相匹配。
  • 核心思路: 给上面的tab_list 里面的所有小li 添加自定义属性,属性值从0开始编号。
  • 当点击tab_list 里面的某个小li,让tab_con 里面对应序号的 内容显示,其余隐藏(排他思想)
<body>
    <style>
        * {
            margin: 0;
            padding: 0;
        }

        li {
            list-style-type: none;
        }

        .tab {
            width: 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: #c81623;
            color: #fff;
        }

        .item_info {
            padding: 20px 0 0 20px;
        }

        .item {
            display: none;
        }
    </style>
    <div class="tab">
        <div class="tab_list">
            <ul>
                <li class="current">商品介绍</li>
                <li>规格与包装</li>
                <li>售后保障</li>
                <li>商品评价(50000)</li>
                <li>手机社区</li>
            </ul>
        </div>
        <div class="tab_con">
            <div class="item" style="display: block;">
                商品介绍模块内容
            </div>
            <div class="item">
                规格与包装模块内容
            </div>
            <div class="item">
                售后保障模块内容
            </div>
            <div class="item">
                商品评价模块内容
            </div>
            <div class="item">
                手机社区模块内容
            </div>
        </div>
    </div>
    <script>
        // 1.上面的选项卡,点击一个底色会变红,其余不变(排他)
        // 获取元素
        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 () {
                // 干掉所有人,其余的li清除class这个类
                for (var i = 0; i < lis.length; i++) {
                    lis[i].className = ''
                }
                // 留下自己
                this.className = 'current'
                // 2.下面的显示内容模块
                var index = this.getAttribute('index')
                // 干掉所有人 让其余的item 这些div隐藏
                for (var i = 0; i < items.length; i++) {
                    items[i].style.display = 'none'
                }
                // 留下我自己 让对应的item 显示出来
                items[index].style.display = 'block'  //block不仅有转换的作用,还有显示的效果
            }
        }
    </script>
</body>

节点层级案例

1. 下拉菜单案例

案例分析:运用子节点

  • 导航栏里面的li 都要有鼠标经过效果,所以需要循环注册鼠标事件
  • 核心原理: 当鼠标经过li 里面的 第二个孩子 ul 显示, 当鼠标离开,则ul 隐藏
    在这里插入图片描述
    在这里插入图片描述
<body>
    <style>
        * {
            margin: 0;
            padding: 0;
        }

        li {
            list-style-type: none;
        }

        a {
            text-decoration: none;
            font-size: 14px;
        }

        .nav {
            margin: 100px;
        }

        .nav>li {
            position: relative;
            float: left;
            width: 80px;
            height: 41px;
            text-align: center;
        }

        .nav li a {
            display: block;
            width: 100%;
            height: 100%;
            line-height: 41px;
            color: #333;
        }

        .nav>li>a:hover {
            background-color: #eee;
        }

        .nav ul {
            display: none;
            position: absolute;
            top: 41px;
            /*因为给了绝对定位,要和上栏错开距离,就设置和div的高度*/
            left: 0;
            width: 100%;
            border-left: 1px solid #FECC5B;
            border-right: 1px solid #FECC5B;
        }

        .nav ul li {
            border-bottom: 1px solid #FECC5B;
        }

        .nav ul li a:hover {
            background-color: #FFF5DA;
        }
    </style>
    <ul class="nav">
        <li>
            <a href="#">微博</a>
            <ul>
                <li>
                    <a href="">私信</a>
                </li>
                <li>
                    <a href="">评论</a>
                </li>
                <li>
                    <a href="">@我</a>
                </li>
            </ul>
        </li>
        <li>
            <a href="#">微博</a>
            <ul>
                <li>
                    <a href="">私信</a>
                </li>
                <li>
                    <a href="">评论</a>
                </li>
                <li>
                    <a href="">@我</a>
                </li>
            </ul>
        </li>
        <li>
            <a href="#">微博</a>
            <ul>
                <li>
                    <a href="">私信</a>
                </li>
                <li>
                    <a href="">评论</a>
                </li>
                <li>
                    <a href="">@我</a>
                </li>
            </ul>
        </li>
        <li>
            <a href="#">微博</a>
            <ul>
                <li>
                    <a href="">私信</a>
                </li>
                <li>
                    <a href="">评论</a>
                </li>
                <li>
                    <a href="">@我</a>
                </li>
            </ul>
        </li>
    </ul>
    <script>
        // 1.获取元素
        var nav = document.querySelector('.nav')
        var lis = nav.children   //得到4个小li
        // 2.循环注册事件
        for (var i = 0; i < lis.length; i++) {
            lis[i].onmouseover = function () {
                this.children[1].style.display = 'block'  //li里面有两个元素,一个a 一个ul
            }
            lis[i].onmouseout = function () {
                this.children[1].style.display = 'none'
            }
        }
    </script>
</body>

2. 简单版发布留言案例

分析:

  • 核心思路: 点击按钮之后,就动态创建一个li,添加到ul 里面。
  • 创建li 的同时,把文本域里面的值通过li.innerHTML 赋值给 li
  • 如果想要新的留言后面显示就用 appendChild 如果想要前面显示就用insertBefore
  • 当把文本域里面的值赋值给li 的时候,多添加一个删除的链接
  • 需要把所有的链接获取过来,当我们点击当前的链接的时候,删除当前链接所在的li
  • 阻止链接跳转需要添加 javascript:void(0); 或者 javascript:;
    在这里插入图片描述
   <style>
        * {
            margin: 0;
            padding: 0;
        }
    
        body {
            padding: 100px;
        }
    
        textarea {
            width: 200px;
            height: 100px;
            border: 1px solid blue;
            outline: none;
            resize: none;
        }
    
        ul {
            margin-top: 50px;
        }
    
        li {
            width: 300px;
            padding: 5px;
            background-color: burlywood;
            color: red;
            font-size: 14px;
            margin: 15px 0;
        }
    
        li a {
            float: right;
        }
    </style>
    <textarea name="" id="">123</textarea>
    <button>发布</button>
    <ul>
    
    </ul>
    <script>
        // 1.获取元素
        var btn = document.querySelector('button')
        var text = document.querySelector('textarea')
        var ul = document.querySelector('ul')
        // 2.注册事件
        btn.onclick = function () {
            if (text.value == '') {
                alert('您没有输入内容')
                return false
            } else {
                // (1)创建元素
                var li = document.createElement('li')
                // 先有li才能赋值
                li.innerHTML = text.value + "<a href = 'javascript:;'>删除</a>"
                // (2)添加元素
                // ul.appendChild(li)
                ul.insertBefore(li, ul.children[0])  //最新一条消息会显示在最前面
                // (3)删除元素
                var as = document.querySelectorAll('a')
                for (var i = 0; i < as.length; i++) {
                    as[i].onclick = function () {
                        ul.removeChild(this.parentNode)
                    }
                }
            }
        }
    </script>
    </body>
  • 9
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 23
    评论
评论 23
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值