JavaScript-添加删除节点-留言板案例

分享一个JavaScript的留言板添加留言、删除留言的小案例,内附详细代码分析、但不涉及数据库操作,只解析底层代码实现思路:

实现效果

运行代码界面:

输入留言进行添加:(最新的留言会在最顶部显示)

删除留言:(点击哪条则删除该条留言)

主要功能效果展示完毕,HTML和CSS样式自定义即可只要页面有一个 input 输入框、一个点击发布留言的按钮和一个展示留言的 ul 元素即可。下面直接上JS代码:

<script>
        // 获取所需元素对象
        var text = document.querySelector('textarea');  // input 输入框
        var btn = document.querySelector('button');     // 发布留言按钮
        var ul = document.querySelector('ul');          // ul 即留言展示列表
        // 监听发布按钮的点击事件
        btn.onclick = function () { // 给发布按钮绑定点击事件
            if (text.value.trim() == '') { // 判断text.value是否为空,即用户是否有输入内容
                alert('不能发布空内容哦!');
                return false;
            } else {    // 用户有输入内容则获取到该内容赋值给创建的元素li进行显示
                // 1.创建元素
                var li = document.createElement('li');
                // 将用户输入的内容赋值给创建的li元素并且在后面添加一个a标签用于后续删除该留言
                li.innerHTML = text.value + "<a href='javascript:;' title='删除该留言'>删除</a>";
                // 2.添加元素
                // ul.appendChild(li);  // 这样写留言是追加到后面显示的
                ul.insertBefore(li, ul.children[0]);    // 让新增的留言在最上面显示,即从下往上显示的顺序

            }
            text.value = '';    // 最后将留言输入框中的内容清空方便再次留言

        }
        // 通过事件冒泡原理监听 ul 中每个 li 标签中 a 链接的点击事件
        ul.onclick = function (e) {
            // e.target 匹配到当前被点击的对象即 a 链接
            // 通过 e.target.parentNode 匹配到被点击的 li
            ul.removeChild(e.target.parentNode) // removeChild() 用于删除该节点
        }
</script>

核心知识:

向页面添加元素节点

我们想要给页面添加一个新的元素分两步:1.创建元素2.添加元素
1.创建元素:element.createElement('要创建的元素标签');
2.添加元素:node.appendChild(child); // node 是父级即添加在哪个父级元素之中,child 是创建好的子级元素,注:这样的添加元素方式类似于数组中的push方法即在后面追加元素
添加节点到指定位置:(主要是添加到指定元素前面显示)
node.insertBefore(child, 指定元素); // “指定元素”指将 child 添加到哪个元素的前面,“指定元素”一定也是node的子元素

创建、添加、删除 整个一个元素的生命周期肯定要介绍完整啊:

3.删除元素:ul.removeChild(child);  // ul 是父元素,child 是 node 中的一个子元素

主要实现思路:这里就是主要运用向页面添加节点和删除节点的功能,将两个功能各自绑定到不同的按键上,如将添加节点的功能给到“发布”按钮,将删除节点的功能给到“删除”按钮,即实现了这样一个简易版的留言板案例。详细解析建议结合JS代码,内含详细注释。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值