文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

JavaScript实现留言板添加删除留言

2024-04-02 19:55

关注

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

实现效果

运行代码界面:

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

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

主要功能效果展示完毕,HTML和CSS样式这里不影响,下面直接上JS代码:


<script>
        // 获取所需元素对象
        var text = document.querySelector('textarea');
        var btn = document.querySelector('button');
        var ul = document.querySelector('ul');
        // 注册事件
        btn.onclick = function () { // 给发布按钮绑定点击事件
            if (text.value == '') { // 判断text.value是否为空,即用户是否有输入内容
                alert('不能发布空内容哦!');
                return false;
            } else {    // 用户有输入内容则获取到该内容赋值给创建的元素li进行显示
                // 1.创建元素
                var li = document.createElement('li');
                li.innerHTML = text.value + "<a href='javascript:;' title='删除该留言'>删除</a>";  // 将用户输入的内容赋值给创建的li元素并且在后面添加一个a标签用于后续删除该留言
                // 2.添加元素
                // ul.appendChild(li);  // 这样写留言是追加到后面显示的
                ul.insertBefore(li, ul.children[0]);    // 让新增的留言在最上面显示,即从下往上显示的顺序
                
                // 删除元素:删除的是当前a标签所在的li节点也就是它的父元素
                var as = document.querySelectorAll('a');
                for (var i = 0; i < as.length; i++) {
                    as[i].onclick = function () {
                        // 需要删除的li是a的父元素即this.parentNode;
                        ul.removeChild(this.parentNode);    // 删除ul里的li节点,而li是当前a标签的父节点,注意它们之间的关系
                    }
                }
            }
            text.value = '';    // 最后将留言输入框中的内容清空方便再次留言
            
        }
</script>

核心知识:

向页面添加元素节点:

我们想要给页面添加一个新的元素分两步:1.创建元素;2.添加元素

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

删除页面元素节点:


node.removeChild(child);  // node是父元素,child是node中的一个子元素

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯