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').οnclick=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').οnclick=function(){
              //右侧入
              var span = document.createElement('span'); //1、创建元素
              span.innerHTML=inputValue;
              var container = document.getElementById('container'); //2、找到父级元素
              container.appendChild(span); //3、在末尾中添加元素
          }
      }
  </script>

 

        

 

转载于:https://www.cnblogs.com/lanleiming/p/5411761.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值