Welcome 微信登录

首页 / 脚本样式 / JavaScript / JS动态创建元素的两种方法

本文为大家分享了js创建元素的两种方法供大家参考,具体内容如下
1)将需要创建的元素,以字符串的形式拼接;找到父级元素,直接对父级元素的innnerHTML进行赋值。
2)使用Document、Element对象自带的一些函数,来实现动态创建元素(创建元素 => 找到父级元素 => 在指定位置插入元素)
一、字符串拼接形式
    为了更好的理解,设定一个应用场景。
    随机生成一组数字,将这组数据渲染为条形图的形式,放在div[id="container"]中,如下图

      

 <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中的信息,根据右边的按钮,分别插入到下方红色矩形的左边或者右边。

      
解决思路分三步:
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>
以上就是本文的全部内容,希望对大家的学习有所帮助。