首頁 > web前端 > js教程 > 主體

JS動態建立元素的兩種方法_javascript技巧

WBOY
發布: 2016-05-16 15:04:35
原創
1041 人瀏覽過

本文為大家分享了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>

登入後複製

以上就是本文的全部內容,希望對大家的學習有所幫助。

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!