>웹 프론트엔드 >JS 튜토리얼 >JS_javascript 기술에서 요소를 동적으로 생성하는 두 가지 방법

JS_javascript 기술에서 요소를 동적으로 생성하는 두 가지 방법

WBOY
WBOY원래의
2016-05-16 15:04:351152검색

이 글에서는 참고용으로 js에서 요소를 생성하는 두 가지 방법을 공유합니다.

1) 문자열 형식으로 생성해야 하는 요소를 연결하고 상위 요소를 찾아 상위 요소의 innerHTML에 직접 값을 할당합니다.

2) Document 및 Element 객체와 함께 제공되는 일부 기능을 사용하여 요소를 동적으로 생성합니다(요소 생성 => 상위 요소 찾기 => 지정된 위치에 요소 삽입)

1. 문자열 연결 형식

이해를 돕기 위해 적용 시나리오를 설정해 보세요.

아래와 같이 무작위로 숫자 집합을 생성하고 이 데이터 집합을 막대 차트로 렌더링한 후 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>

2. 문서 및 요소 개체와 함께 제공되는 일부 기능 사용

또한 아래와 같이 적용 시나리오를 설정합니다

입력란에 정보를 얻어 오른쪽 버튼에 따라 아래 빨간색 직사각형의 왼쪽이나 오른쪽에 삽입합니다.

 

해결책은 세 단계로 나뉩니다.

1. 요소 생성: Document.createElement()
2. 상위 요소 찾기: ID, 이름, 태그 이름, 클래스를 사용하고 지정된 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>

위 내용은 이 글의 전체 내용입니다. 모든 분들의 공부에 도움이 되었으면 좋겠습니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.