JavaScript实现动态添加、移除元素或属性的方法分析


Posted in Javascript onJanuary 03, 2019

本文实例讲述了JavaScript实现动态添加、移除元素或属性的方法。分享给大家供大家参考,具体如下:

JavaScript 动态添加、移除元素

appendChild(newnode)
向节点的子节点列表的末尾添加新的子节点。

insertBefore(newnode, existingnode)
在已有子节点之前插入新的子节点。

removeChild(node)
删除元素的某个指定的子节点,并以 Node 对象返回被删除的节点,如果节点不存在则返回 null。

innerHTML
属性设置或返回表格行的开始和结束标签之间的 HTML。

测试用例

<html>
  <head>
    <style type="text/css">
      .style1 { background-color:yellow; width:200px;height:100px;float:left;}
      .style2 { background-color:#aa0; width:200px;height:100px;float:left;}
      .style3 { background-color:rgb(0,200,200); width:200px;height:100px;float:left;}
      .item-style {background-color:pink;}
    </style>
    <script type="text/javascript">
      function addElement1() {
        var container = document.getElementById("container1");
        var elem1 = document.createElement("div");
        elem1.setAttribute("class", "item-style");
        var textnode1 = document.createTextNode("appendChild");
        elem1.appendChild(textnode1);
        container.appendChild(elem1);
        var middleChild = document.getElementById("middle-child");
        var elem2 = document.createElement("div");
        elem2.setAttribute("class", "item-style");
        var textnode2 = document.createTextNode("insertBefore");
        elem2.appendChild(textnode2);
        container.insertBefore(elem2, middleChild);
      }
      function addElement2() {
        var container = document.getElementById("container2");
        container.innerHTML = "<div>Hello World \"2\"</div>";
      }
      function removeNode() {
        var container = document.getElementById("container3");
        var myNode = document.getElementById("myNode");
        container.removeChild(myNode);
      }
      function operateElements() {
        addElement1();
        addElement2();
        removeNode();
      }
    </script>
  </head>
  <body onload="operateElements()">
    <div id="container1" class="style1">
      <div id="middle-child">Middle Child</div>
    </div>
    <div id="container2" class="style2"></div>
    <div id="container3" class="style3"><p id="myNode">Hello World</p></div>
    <div style="clear:both;"/>
    <button onclick="operateElements()">Operate Elements</button>
  </body>
</html>

 JavaScript实现动态添加、移除元素或属性的方法分析

JavaScript 动态添加、移除属性

setAttribute(attributename, attributevalue)
添加指定的属性,并为其赋指定的值。将属性设置为undefined等同于删除。

removeAttribute(attributename)
删除指定的属性。

getAttributeNode(attributename)
以 Attr 对象返回指定属性名的属性值。

removeAttributeNode(attributenode)
删除 Attr 形式指定的属性,同时返回被删除的Attr 形式的属性。

测试用例

<html>
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <script type="text/javascript">
      function operateAttributes() {
        var node2 = document.getElementById("node2");
        //设置font-style和font-size无效,这些属性脱离style单独设置是无效的
        node2.setAttribute("style", "color:red;");
        var node3 = document.getElementById("node3");
        node3.setAttribute("font-size", undefined);
        var node4 = document.getElementById("node4");
        //font-style和font-size的remove无效,因为它们没有单独存在
        node4.removeAttribute("font-size");
        var node5 = document.getElementById("node5");
        //无法获取font-style和font-size
        var attributeNode = node5.getAttributeNode("style");
        var attr = node5.removeAttributeNode(attributeNode);
        node5.innerHTML = "attr=" + attr + ", attr.name=" + attr.name + ", attr.value=" + attr.value;
      }
    </script>
  </head>
  <body onload="operateAttributes()">
    <p id="node0" style="font-style:italic;font-size:12px;">0 Hello World</p>
    <p id="node1" font-size="12px" font-style="italic">1 Hello World : font-size、font-style等,这些属性脱离style单独设置是无效的</p>
    <p id="node2" style="font-style:italic;font-size:12px;">2 Hello World setAttribute</p>
    <p id="node3" style="font-style:italic;font-size:12px;">3 Hello World setAttribute</p>
    <p id="node4" style="font-style:italic;font-size:12px;">4 Hello World removeAttribute</p>
    <p id="node5" style="font-style:italic;font-size:12px;">5 Hello World getAttributeNode & removeAttributeNode</p>
  </body>
</html>

JavaScript实现动态添加、移除元素或属性的方法分析

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
toString()一个会自动调用的方法
Feb 08 Javascript
JS input文本框禁用右键和复制粘贴功能的代码
Apr 15 Javascript
jQuery EasyUI NumberBox(数字框)的用法
Jul 08 Javascript
如何使用Javascript获取距今n天前的日期
Jul 08 Javascript
查找Oracle高消耗语句的方法
Mar 22 Javascript
JQuery中$.each 和$(selector).each()的区别详解
Mar 13 Javascript
JS实现将Asp.Net的DateTime Json类型转换为标准时间的方法
Aug 02 Javascript
jquery点赞功能实现代码 点个赞吧!
May 29 jQuery
Angularjs 双向绑定时字符串的转换成数字类型的问题
Jun 12 Javascript
vue2.0 datepicker使用方法
Feb 04 Javascript
浅谈vue中关于checkbox数据绑定v-model指令的个人理解
Nov 14 Javascript
使用Typescript和ES模块发布Node模块的方法
May 25 Javascript
JavaScript实现shuffle数组洗牌操作示例
Jan 03 #Javascript
JavaScript实现数字前补“0”的五种方法示例
Jan 03 #Javascript
35个最好用的Vue开源库(史上最全)
Jan 03 #Javascript
原生js实现移动端Touch轮播图的方法步骤
Jan 03 #Javascript
发布一款npm包帮助理解npm的使用
Jan 03 #Javascript
用node开发并发布一个cli工具的方法步骤
Jan 03 #Javascript
详解Vue基于vue-quill-editor富文本编辑器使用心得
Jan 03 #Javascript
You might like
PHP中计算字符串相似度的函数代码
2012/12/29 PHP
php设计模式之简单工厂模式详解
2014/09/04 PHP
在html文件中也可以执行php语句的方法
2015/04/09 PHP
PHP判断是否为空的几个函数对比
2015/04/21 PHP
详解Window7 下开发php扩展
2015/12/31 PHP
thinkPHP通用控制器实现方法示例
2017/11/23 PHP
使用jQuery的ajax功能实现的RSS Reader 代码
2009/09/03 Javascript
Jquery下attr和removeAttr的使用方法
2010/12/28 Javascript
JS中不为人知的五种声明Number的方式简要概述
2013/02/22 Javascript
JS实现自适应高度表单文本框的方法
2015/02/25 Javascript
js的flv视频播放器插件使用方法
2015/06/23 Javascript
jQuery实现选中弹出窗口选择框内容后赋值给文本框的方法
2015/11/23 Javascript
Js删除数组中某一项或几项的几种方法(推荐)
2016/07/27 Javascript
Vue-Router实现页面正在加载特效方法示例
2017/02/12 Javascript
vue组件中使用props传递数据的实例详解
2018/04/08 Javascript
详解微信小程序回到顶部的两种方式
2019/05/09 Javascript
基于jQuery的时间戳与日期间的转化
2019/06/21 jQuery
扫微信小程序码实现网站登陆实现解析
2019/08/20 Javascript
vue-cli 为项目设置别名的方法
2019/10/15 Javascript
python条件和循环的使用方法
2013/11/01 Python
python进程类subprocess的一些操作方法例子
2014/11/22 Python
python高手之路python处理excel文件(方法汇总)
2016/01/07 Python
学习python中matplotlib绘图设置坐标轴刻度、文本
2018/02/07 Python
Python3.7 读取 mp3 音频文件生成波形图效果
2019/11/05 Python
python 经典数字滤波实例
2019/12/16 Python
Book Depository亚太地区:一家领先的国际图书零售商
2019/05/05 全球购物
土木工程毕业生自荐信
2013/09/21 职场文书
双十佳事迹材料
2014/01/29 职场文书
社区平安建设汇报材料
2014/08/14 职场文书
大学生职业生涯规划大赛作品(精品)
2014/09/17 职场文书
交通事故委托书范本精选
2014/10/04 职场文书
老人节标语大全
2014/10/08 职场文书
关爱留守儿童捐款倡议书
2015/04/27 职场文书
安全生产协议书
2016/03/22 职场文书
喜迎建国70周年:有关爱国的名言名句
2019/09/24 职场文书
如何用Laravel包含你自己的帮助函数
2021/05/27 PHP