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 相关文章推荐
腾讯的ip接口 方便获取当前用户的ip地理位置
Nov 25 Javascript
谈谈javascript中使用连等赋值操作带来的问题
Nov 26 Javascript
第一次接触神奇的Bootstrap菜单和导航
Aug 01 Javascript
js控制一个按钮是否可点击(可使用)disabled的实例
Feb 14 Javascript
Bootstrap表格使用方法详解
Feb 17 Javascript
解决AjaxFileupload 上传时会出现连接重置的问题
Jul 07 Javascript
微信小程序scroll-view仿拼多多横向滑动滚动条
Apr 21 Javascript
每天学点Vue源码之vm.$mount挂载函数
Mar 11 Javascript
layui 解决富文本框form表单提交为空的问题
Oct 26 Javascript
swiper自定义分页器的样式
Sep 14 Javascript
Vue 打包的静态文件不能直接运行的原因及解决办法
Nov 19 Vue.js
低门槛开发iOS、Android、小程序应用的前端框架详解
Oct 16 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
JavaScript创建命名空间的5种写法
2014/06/24 PHP
ThinkPHP中数据操作案例分析
2015/09/27 PHP
yii2带搜索功能的下拉框实例详解
2016/05/12 PHP
在页面上点击任一链接时触发一个事件的代码
2007/04/07 Javascript
javascript 得到变量类型的函数
2010/05/19 Javascript
仅IE6/7/8中innerHTML返回值忽略英文空格的问题
2011/04/07 Javascript
js字符串的各种格式的转换 ToString,Format
2011/08/08 Javascript
深入解析JavaScript中的变量作用域
2013/12/06 Javascript
js导航栏单击事件背景变换示例代码
2014/01/13 Javascript
jQuery超简单选项卡完整实例
2015/09/26 Javascript
jQuery+css3实现转动的正方形效果(附demo源码下载)
2016/01/27 Javascript
深入浅析JavaScript中的constructor
2016/04/19 Javascript
Jquery获取当前城市的天气信息
2016/08/05 Javascript
Canvas 制作动态进度加载水球详解及实例代码
2016/12/09 Javascript
你不知道的 javascript【推荐】
2017/01/08 Javascript
详解element-ui中form验证杂记
2019/03/04 Javascript
使用typescript构建Vue应用的实现
2019/08/26 Javascript
微信小程序制作扭蛋机代码实例
2019/09/24 Javascript
零基础写python爬虫之抓取糗事百科代码分享
2014/11/06 Python
python 列表删除所有指定元素的方法
2018/04/19 Python
python3.6.3转化为win-exe文件发布的方法
2018/10/31 Python
详解用Python练习画个美队盾牌
2019/03/23 Python
python3通过qq邮箱发送邮件以及附件
2020/05/20 Python
连卡佛中国官网:Lane Crawford中文站
2018/01/27 全球购物
英国最大的汽车配件在线商店:Euro Car Parts
2019/09/30 全球购物
解释DataSet(ds) 和 ds as DataSet 的含义
2014/07/27 面试题
安全生产中长期规划实施方案
2014/02/21 职场文书
公司活动方案范文
2014/03/06 职场文书
2014坚持党风廉政建设思想汇报
2014/09/18 职场文书
群众路线教育实践活动对照检查材料
2014/09/22 职场文书
群众路线四风自我剖析材料
2014/10/08 职场文书
银行求职信范文怎么写
2015/03/20 职场文书
公司要求试用期员工提交“述职报告”,该怎么写?
2019/07/17 职场文书
python 自动刷新网页的两种方法
2021/04/20 Python
Golang 如何实现函数的任意类型传参
2021/04/29 Golang
Python时间操作之pytz模块使用详解
2022/06/14 Python