>일일 프로그램 >HTML 지식 >네이티브 JS는 흰색 블록 게임을 밟지 마세요(5)를 구현합니다.

네이티브 JS는 흰색 블록 게임을 밟지 마세요(5)를 구현합니다.

藏色散人
藏色散人원래의
2018-12-28 11:41:455830검색



네이티브 JS로 Don't Step on White Blocks 게임을 구현하는 방법에 대해서는 이전 기사 " Don't Step on White Blocks Game 구현"의 내용을 계속 따르겠습니다. with Native JS (4)"를 통해 CDiv 방식의 구체적인 코드 분석을 만나보실 수 있습니다.

네이티브 JS는 흰색 블록 게임을 밟지 마세요(5)를 구현합니다.

Don't Step on White Blocks 게임 소스 코드의 관련 js 부분은 다음과 같습니다.

<script>
    var main = document.getElementById(&#39;main&#39;)
    go = document.getElementById(&#39;go&#39;)
    count = document.getElementById(&#39;count&#39;);
//设置四种颜色
    cols = [&#39;#1AAB8A&#39;, &#39;#E15650&#39;, &#39;#121B39&#39;, &#39;#80A84E&#39;];
//动态创建div
    function CDiv(classname) {
        var Div = document.createElement(&#39;div&#39;)
        //生成随机数
        index = Math.floor(Math.random() * 4)
        //添加class
        Div.className = classname
        //循环创建div为块
        for (var i = 0; i < 4; i++) {
            var iDiv = document.createElement(&#39;div&#39;)
            Div.appendChild(iDiv)
        }
        if (main.children.length == 0) {
            main.appendChild(Div);
        } else {
            main.insertBefore(Div, main.children[0]);
        }
 
        Div.children[index].style.backgroundColor = cols[index];
        Div.children[index].className = "i";
    }
</script>

이 코드에서는 document.createElement('div')를 통해 변수 iDiv를 정의합니다. for 루프 body 를 사용한 다음,appendChild() 메서드를 반복하여 이전에 동적으로 생성된 Div에 하위 요소(예: iDiv)를 추가합니다.

여기서 동적으로 생성된 Div는 게임의 행을 나타내고, 추가된 iDiv는 연속된 4개의 사각형을 나타냅니다.

그런 다음 if 판단 문을 사용하여 main 아래에 하위 요소가 있는지 확인하고, 존재하지 않는 경우appendChild 메소드를 통해 하위 노드를 추가하고, insertBefore를 통해 기존 하위 노드 앞에 새 하위 노드를 삽입합니다. .

마지막으로 난수를 생성하여 연속된 블록에 무작위로 배경색을 추가하고 "i" 클래스를 추가합니다. 여기서는 변수 cols를 네 가지 색상으로 정의합니다. ㅋㅋ

네이티브 JS는 흰색 블록 게임을 밟지 마세요(5)를 구현합니다.appendChild()

메소드는 노드의 하위 노드 목록 끝에 새 하위 노드를 추가할 수 있습니다.

insertBefore()

메서드는 지정한 기존 하위 노드 앞에 새 하위 노드를 삽입합니다.

이 섹션은 Don't Step on White Blocks 게임의 CDiv 방법에 대한 자세한 소개입니다. 기사가 길기 때문에 나머지 js 코드는 이후 기사에서 계속 분석하겠습니다.

위 내용은 네이티브 JS는 흰색 블록 게임을 밟지 마세요(5)를 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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