博客列表 >DOM元素的增删改及留言板案例

DOM元素的增删改及留言板案例

OC的PHP大牛之路
OC的PHP大牛之路原创
2022年07月27日 17:40:36329浏览

DOM元素的增删改

  1. // 创建新元素:createElement()
  2. const ul=document.createElement('ul');
  3. // 添加元素:append()
  4. document.body.append(ul);
  5. for (let i=0;i<5;i++){
  6. const li=document.createElement('li');
  7. li.append('item-'+(i+1));
  8. ul.append(li);
  9. }


  1. // 在某节点之前插入:before
  2. const li=document.createElement('li');
  3. li.append('new item');
  4. li.style.color='blue';
  5. // 获取第二个元素
  6. const item=ul.querySelector('li:nth-of-type(2)');
  7. // 当前节点之前插入.before(新节点)
  8. item.before(li);
  9. // 克隆
  10. let newNode=li.cloneNode(true);
  11. // 当前节点之后插入.after(新节点)
  12. item.after(newNode);
  13. ul.style.border='2px solid yellow';
  14. const h3=document.createElement('h3');
  15. h3.append('商品列表')
  16. h3.style.color='red';
  17. // 在当前列表的前面插入一个标题:insertAdjacentElement('插入位置',元素)
  18. // beforebegin:开始标签之前
  19. ul.insertAdjacentElement('beforebegin',h3);
  20. // afterbegin:开始标签之后
  21. ul.insertAdjacentHTML('afterbegin','<li style="color:red">hello</li>');
  22. // beforeend:结束标签之前
  23. ul.insertAdjacentHTML('beforeend','<li style="color:red">world</li>');
  24. // afterend:结束标签之后
  25. ul.insertAdjacentHTML('afterend','<h4 style="color:red">共计:9个</h4>');


  1. // 替换:replaceChild()
  2. // 被替换的旧节点
  3. const targetNode=ul.querySelector('li:last-of-type');
  4. const link=document.createElement('a');
  5. // 新节点
  6. link.href='www.php.cn';
  7. link.append('php中文网');
  8. // parentNode.replaceChild(新节点,被替换的旧节点)
  9. ul.replaceChild(link,targetNode);
  10. // 移除:remove
  11. ul.firstElementChild.remove();
  12. ul.lastElementChild.remove();
  13. ul.querySelector('li:nth-of-type(2)').remove();
  14. ul.querySelector('li:nth-of-type(3)').remove();


留言板案例

  1. <body>
  2. <header>
  3. <h3>留言板</h3>
  4. </header>
  5. <main>
  6. <input type="text" onkeydown="addMsg(this)" placeholder="请输入留言" autofocus />
  7. <ul class="list"></ul>
  8. </main>
  9. <script>
  10. function addMsg(ele) {
  11. if (event.key === 'Enter') {
  12. if (ele.value.length === 0) {
  13. alert('留言不能为空');
  14. ele.focus();
  15. return false;
  16. }
  17. const ul = document.querySelector('.list');
  18. ele.value = ele.value + '<button onclick="del(this.parentNode)">删除</button>';
  19. ul.insertAdjacentHTML('afterbegin', `<li>${ele.value}</li>`);
  20. ele.value = null;
  21. }
  22. }
  23. function del(ele) {
  24. return confirm('是否删除?') ? ele.remove() : false;
  25. }
  26. </script>
  27. </body>
声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议