浅析JS动态创建元素【两种方法】


Posted in Javascript onApril 20, 2016

前言

创建元素有两种方法

      1)将需要创建的元素,以字符串的形式拼接;找到父级元素,直接对父级元素的innnerHTML进行赋值。

      2)使用Document、Element对象自带的一些函数,来实现动态创建元素(创建元素 => 找到父级元素 => 在指定位置插入元素)

 

一、字符串拼接形式

    为了更好的理解,设定一个应用场景。

    随机生成一组数字,将这组数据渲染为条形图的形式,放在div[id="container"]中,如下图

    浅析JS动态创建元素【两种方法】   

<div id="container">
 </div>
 <script>
   window.onload = function () {
     var str='';
     for(var i=0; i<30 ;i++){
       var r = parseInt(Math.random()*100); //随机生成一个数字
       str += '<div>'+r+'</div>'; //拼接str
     }
     document.getElementById('container').innerHTML=str;
   }
 </script>

 二、使用Document、Element对象自带的一些函数

       也设定一个应用场景,如下图

       获取input中的信息,根据右边的按钮,分别插入到下方红色矩形的左边或者右边。

       浅析JS动态创建元素【两种方法】

       解决思路分三步

  1. 创建元素:Document.createElement()
  2. 找到父级元素 :可以通过Id、name、标签名、class、匹配指定的css选择器
  3. 在指定位置插入元素:element.appendChild()、element.insertBefore()       

 实现代码:        

<div id="div-input">
  <input type="text" id="txt_input" value="4"/>
  <input type="button" id="leftInsert" value="左侧入" />
  <input type="button" id="rightInsert" value="右侧入" />
</div>
<div id="container">
  <span>1</span>
  <span>2</span>
  <span>3</span>
</div>
 <script>
   window.onload = function () {
     var inputValue= document.getElementById('txt_input').value;
     document.getElementById('leftInsert').onclick=function(){
       //左侧入
       var span = document.createElement('span'); //1、创建元素
       span.innerHTML=inputValue;
       var container = document.getElementById('container'); //2、找到父级元素
        container.insertBefore(span,container.childNodes[0]);//插入到最左边
     }
     document.getElementById('rightInsert').onclick=function(){
       //右侧入
       var span = document.createElement('span'); //1、创建元素
       span.innerHTML=inputValue;
       var container = document.getElementById('container'); //2、找到父级元素
       container.appendChild(span); //3、在末尾中添加元素
     }
   }
 </script>

以上这篇浅析JS动态创建元素【两种方法】就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
一些常用的JS功能函数(2009-06-04更新)
Jun 04 Javascript
动态改变div的z-index属性的简单实例
Aug 08 Javascript
可以用鼠标拖动的DIV实现思路及代码
Oct 21 Javascript
jquery实现点击消失的代码
Mar 03 Javascript
jQuery使用ajaxSubmit()提交表单示例
Apr 04 Javascript
js 数据存储和DOM编程
Feb 09 Javascript
Angular使用 ng-img-max 调整浏览器中的图片的示例代码
Aug 17 Javascript
Vue.js进行查询操作的实例详解
Aug 25 Javascript
浅析Javascript中双等号(==)隐性转换机制
Oct 27 Javascript
通过js示例讲解时间复杂度与空间复杂度
Aug 06 Javascript
js实现简单贪吃蛇游戏
May 15 Javascript
使用原生JS实现滚轮翻页效果的示例代码
May 31 Javascript
纯JS代码实现一键分享功能
Apr 20 #Javascript
JavaScript动态生成二维码图片
Apr 20 #Javascript
JS动态创建元素的两种方法
Apr 20 #Javascript
深入浅析Extjs中store分组功能的使用方法
Apr 20 #Javascript
JS实时弹出新消息提示框并有提示音响起的实现代码
Apr 20 #Javascript
JavaScript  cookie 跨域访问之广告推广
Apr 20 #Javascript
JavaScript实现简单Tip提示框效果
Apr 20 #Javascript
You might like
PHP运行环境配置与开发环境的配置(图文教程)
2013/06/04 PHP
Linux Apache PHP Oracle 安装配置(具体操作步骤)
2013/06/17 PHP
PHP中使用Memache作为进程锁的操作类分享
2015/03/30 PHP
thinkPHP2.1自定义标签库的导入方法详解
2016/07/20 PHP
PHP二分查找算法示例【递归与非递归方法】
2016/09/29 PHP
Ubuntu VPS中wordpress网站打开时提示”建立数据库连接错误”的解决办法
2016/11/03 PHP
php获取当前url地址的方法小结
2017/01/10 PHP
PHP实现浏览器中直接输出图片的方法示例
2018/03/14 PHP
可实现多表单提交的javascript函数
2007/08/01 Javascript
JS文本框不能输入空格验证方法
2013/03/19 Javascript
javascript:文字不间断向左移动的实例代码
2013/08/08 Javascript
Javascript排序算法之合并排序(归并排序)的2个例子
2014/04/04 Javascript
Javascript中的匿名函数与封装介绍
2015/03/15 Javascript
javascript实现控制浏览器全屏
2015/03/30 Javascript
浅谈javascript属性onresize
2015/04/20 Javascript
客户端验证用户名和密码的方法详解
2016/06/16 Javascript
AngularJS实用开发技巧(推荐)
2016/07/13 Javascript
Vue弹出菜单功能的实现代码
2018/09/12 Javascript
微信小程序开发之路由切换页面重定向问题
2018/09/18 Javascript
解读Python中degrees()方法的使用
2015/05/18 Python
python检查字符串是否是正确ISBN的方法
2015/07/11 Python
浅谈python新手中常见的疑惑及解答
2016/06/14 Python
详解python中的文件与目录操作
2017/07/11 Python
高效使用Python字典的清单
2018/04/04 Python
python3 面向对象__类的内置属性与方法的实例代码
2018/11/09 Python
HTML5 Canvas自定义圆角矩形与虚线示例代码
2013/08/02 HTML / CSS
KIKO MILANO西班牙官网:意大利领先的化妆品和护肤品品牌
2019/05/03 全球购物
Guess欧洲官网:美国服饰品牌
2019/08/06 全球购物
商业活动邀请函
2014/02/04 职场文书
活动总结模板
2014/05/09 职场文书
给医院的感谢信
2015/01/21 职场文书
法人代表资格证明书
2015/06/18 职场文书
高老头读书笔记
2015/06/30 职场文书
幼儿园体操比赛口号
2015/12/25 职场文书
Vue图片裁剪组件实例代码
2021/07/02 Vue.js
win10蓝屏0xc0000001安全模式进不了怎么办?win10出现0xc0000001的解决方法
2022/08/05 数码科技