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 相关文章推荐
基于jQuery的Spin Button自定义文本框数值自增或自减
Jul 17 Javascript
利用google提供的API(JavaScript接口)获取网站访问者IP地理位置的代码详解
Jul 24 Javascript
javascript 广告后加载,加载完页面再加载广告
Nov 25 Javascript
javascript验证身份证号
Mar 03 Javascript
JavaScript+Java实现HTML页面转为PDF文件保存的方法
May 30 Javascript
Ionic默认的Tabs模板使用实例
Aug 29 Javascript
ES2015 Symbol 一种绝不重复的值
Dec 25 Javascript
非常优秀的JS图片轮播插件Swiper的用法
Jan 03 Javascript
用 js 的 selection range 操作选择区域内容和图片
Apr 18 Javascript
JS使用tween.js动画库实现轮播图并且有切换功能
Jul 17 Javascript
vue中使用微信公众号js-sdk踩坑记录
Mar 29 Javascript
js删除指定位置超链接中含有百度与360的标题
Jan 06 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
js下函数般调用正则的方法附代码
2008/06/22 PHP
php5 pdo新改动加载注意事项
2008/09/11 PHP
ThinkPHP安装和设置
2015/07/27 PHP
PHP递归遍历文件夹去除注释并压缩php源代码的方法示例
2018/05/23 PHP
[Web]防止用户复制页面内容和另存页面的方法
2009/02/06 Javascript
js展开闭合效果演示代码
2013/07/24 Javascript
扒一扒JavaScript 预解释
2015/01/28 Javascript
深入理解JavaScript编程中的原型概念
2015/06/25 Javascript
BOM系列第一篇之定时器setTimeout和setInterval
2016/08/17 Javascript
微信小程序(应用号)简单实例应用及实例详解
2016/09/26 Javascript
JS实现AES加密并与PHP互通的方法分析
2017/04/19 Javascript
Javascript实现页面滚动时导航智能定位
2017/05/06 Javascript
jQuery实现导航栏头部菜单项点击后变换颜色的方法
2017/07/19 jQuery
详解Vue快速零配置的打包工具——parcel
2018/01/16 Javascript
React Native中Mobx的使用方法详解
2018/12/04 Javascript
js实现一个页面多个倒计时的3种方法
2019/02/25 Javascript
vue解决花括号数据绑定不成功的问题
2019/10/30 Javascript
微信小程序地图实现展示线路
2020/07/29 Javascript
[29:10]Ti4 冒泡赛第二天 NEWBEE vs Titan 3
2014/07/15 DOTA
[00:43]拉比克至宝魔导师密钥展示
2018/12/20 DOTA
python的keyword模块用法实例分析
2015/06/30 Python
Python中模块pymysql查询结果后如何获取字段列表
2017/06/05 Python
Python使用pickle模块实现序列化功能示例
2018/07/13 Python
医学检验专业个人求职信范文
2013/12/04 职场文书
11月红领巾广播稿
2014/01/17 职场文书
初中同学聚会邀请函
2014/02/03 职场文书
廉洁校园实施方案
2014/05/25 职场文书
物理学专业自荐信
2014/06/11 职场文书
安全生产知识竞赛活动总结
2014/07/07 职场文书
2014年乡镇领导个人整改措施
2014/09/19 职场文书
培训班开班主持词
2015/07/02 职场文书
幼儿园园长六一致辞
2015/07/31 职场文书
描述鲁迅的名言整理,一生受用
2019/08/08 职场文书
MySQL EXPLAIN输出列的详细解释
2021/05/12 MySQL
MySQL子查询中order by不生效问题的解决方法
2021/08/02 MySQL
Python+Selenium自动化环境搭建与操作基础详解
2022/03/13 Python