jquery留言板代码(JavaScript实现留言板添加删除留言)
类别:编程学习 浏览量:1383
时间:2021-10-16 00:18:47 jquery留言板代码
JavaScript实现留言板添加删除留言本文分享一个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代码,内含详细注释。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。
您可能感兴趣
- nodejs启动web服务器(使用NODE.JS创建一个WEBSERVER服务器的步骤)
- js中拼接字符串的几种方法
- python json转换字符串(python3 json数据格式的转换dumps/loads的使用、dict to str/str to dict、json字符串/字典)
- extjs XTemplate的实例
- extjs column列布局
- nodejs请求页面(node.js+postman实现模拟HTTP服务器与客户端交互)
- vue.js开发网站的关键技术(Vue.js项目前端多语言方案的思路与实践)
- php 结果集转json(PHP的JSON封装、转变及输出操作示例)
- extjs table布局
- vuejs过滤器使用教程(vue3删除过滤器的原因)
- js中Math对象的用法
- vuejs全家桶入门教程交流(Vue全家桶入门基础教程)
- angularjs使用指令(详解Angular路由动画及高阶动画函数)
- js绘制平滑路径(如何利用Javascript生成平滑曲线详解)
- 通过js获取Url的参数值
- js中parent和opener的区别
- 收藏 春节假期,这些景区巨划算(收藏春节假期这些景区巨划算)
- 景区游玩,这些安全知识要牢记(这些安全知识要牢记)
- 各地出招烘 热 旅游(各地出招烘热旅游)
- 2021款起亚霸锐到店了 更换车标,竞争宝马X5有戏吗(2021款起亚霸锐到店了)
- 新款起亚霸锐实拍,比普拉多气派,配3.0T V6,引入国内或许能大卖(新款起亚霸锐实拍)
- ()
热门推荐
- 浏览器内核有哪些
- sql server批量导出数据(SQL Server 批量插入数据的完美解决方案)
- canvas 动画线段(canvas简单连线动画的实现代码)
- apache安全配置使用教程(正确配置与维护Apache安全性设置方法)
- 什么是依赖倒置原则
- php项目开发实例(php项目中类的自动加载实例讲解)
- vmwareesxi怎么安装(vmware esxi6.5安装使用详细步骤)
- vue 富文本图片上传(vue.js云存储实现图片上传功能)
- mysql密码设置(mysql密码中有特殊字符&在命令行下登录的操作)
- nginx和apache服务器配置(Apache、Nginx 服务配置服务器端包含SSI)