博客列表 >购物车的单个删除与编辑功能

购物车的单个删除与编辑功能

源逸
源逸原创
2019年06月01日 18:27:15833浏览

单个删除

1.单个删除给每个删除按钮添加name属性

2.循环遍历删除,并添加单击事件进行删除,需要删除的当前删除按钮的父节点


编辑

  1. 编辑按钮添加name属性

  2. 循环遍历添加单击事件,寻找当前编辑按钮的父级元素的兄弟元素,就是内容td节点进行编辑操作

实例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>编辑与单个删除(使用事件监听函数,对页面的数据进行单个删除和编辑)2019.05.14实例</title>
    <style>
        /*表格与单元素添加边框*/
        table, th, td {
            border: 1px solid black;
        }
        /*设置表格样式, 折叠边框线并设置宽度*/
        table {
            border-collapse: collapse;
            width: 600px;
        }

        /*设置标题行背景*/
        table thead tr:first-of-type {
            background-color: lightblue;
        }

        /*选择每一行的第一列*/
        table tr td:first-of-type {
            text-align: center;
        }
    </style>
</head>
<body>
<div>
<table name="care">
    <caption>购物车</caption>
    <thead>
    <tr>
        <th style="width: 30px;"><input type="checkbox" id="all"></th>
        <th>商品</th>
        <th>操作</th>
    </tr>
    </thead>


    <tbody>
    <tr>
        <td><input type="checkbox" name="user-select"></td>
        <td>华为HUAWEI MateBook 14 全面屏轻薄性能笔记本电脑</td>
        <td><button name="edit">编辑</button> <button name="delOne" >删除</button></td>
    </tr>
    <tr>
        <td><input type="checkbox" name="user-select"></td>
        <td>联想(Lenovo)拯救者Y7000英特尔酷睿i5 15.6英寸游戏笔记本电脑</td>
        <td><button name="edit">编辑</button> <button name="delOne" >删除</button></td>
    </tr>
    <tr>
        <td><input type="checkbox" name="user-select"></td>
        <td>小米 (MI)Ruby 2019款 15.6英寸金属轻薄笔记本电脑</td>
        <td><button name="edit">编辑</button> <button name="delOne" >删除</button></td>
    </tr>
    <tr>
        <td><input type="checkbox" name="user-select"></td>
        <td>Apple Macbook Pro 13.3[带触控栏]深空灰 </td>
        <td><button name="edit">编辑</button> <button name="delOne" >删除</button></td>
    </tr>
    </tbody>
</table>

<button id="del-all" disabled>全部删除</button>
</div>

<script>
    //全选按钮
    var all = document.getElementById('all');

    //商品复选框
    var checkboxes = document.getElementsByName('user-select');

    //全选删除按钮
    var delBut = document.getElementById('del-all');

    //全选复选框:input事件
    all.addEventListener('input',eleAll,false);

    function eleAll() {
       if(this.checked === true){
           Object.keys(checkboxes).forEach(function (key) {
               checkboxes[key].checked = true;
           });
           delBut.disabled = false;
       } else {
           Object.keys(checkboxes).forEach(function (key) {
               checkboxes[key].checked = false;
           });
           delBut.disabled = true;
       }
    }

    //全选删除按钮事件:click
    delBut.addEventListener('click',delAll,false);

    function delAll() {
        if(confirm('是否删除')){
            var tbody = document.getElementsByTagName('table')[0].tBodies[0];
            tbody.innerHTML = '';
            delBut.disabled = true;
            all.checked = false;
            all.disabled = true;

            var p = document.createElement('p');
            p.style.color = 'red';
            p.innerText = '这也太穷了吧,买点东西吧!';
            document.body.appendChild(p);
        }
    }

    //单个删除
    var delOne = document.getElementsByName('delOne');

    //click
    Object.keys(delOne).forEach(function (key) {
        delOne[key].addEventListener('click',delEleOne,false);
    });

    function delEleOne() {
        return confirm('是否删除') ? this.parentElement.parentElement.remove() : false;
    }

    //编辑
    var edit = document.getElementsByName('edit');

    Object.keys(edit).forEach(function (key) {
        edit[key].addEventListener('click',editEle,false);
    });

    function editEle() {
        //获取按钮父级元素的同级兄弟元素:内容的td
        var td = this.parentElement.previousElementSibling;
        var oldContent = td.innerHTML;
        var newContent = prompt('请输入要更新的内容',oldContent);

        if(newContent !== null && newContent !== ''){
            td.innerHTML = newContent;
        }else{
            return false;
        }
    }
</script>
</body>
</html>
QQ图片20190601182626.png运行实例 »

点击 "运行实例" 按钮查看在线实例


声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议