2017-06-04 64 views
0

HTML如何讓我的隨機生成的div出現在容器div內?

<div id="container"> 
     <div id="wrapper"> 

     </div> 
     <span id = "waveNum">Current Wave: 0</span> 
     <input type = "button" value = "Start Game" onclick = "startGame()"></input> 
    </div> 

    <script src="https://code.jquery.com/jquery-2.1.3.js"></script> 
    <script src="main.js"></script> 
    </body> 

的Javascript

var keyArray = []; 
var currentWave = 1; 


var player; 
var player2; 
function initiate(){ 
    player = new createPlayer(150,50,"player1","relative","blue"); 
    player2 = new createPlayer(150,0,"player2","relative","green"); 
} 

function startGame() { 
    point(); 
} 

function createPlayer(l,t,id,pos,color){ 
    this.speed = 3; 
    this.width = 25; 
    this.height = 25; 
    this.left = l; 
    this.top = t; 
    this.id = id; 
    this.model = $("<div id=" + id + "/>") 
     .css({"backgroundColor":color,"height":this.height,"width":this.width, 
      "left":this.left,"top":this.top,"position":pos}) 

    $('#wrapper').append($(this.model)); 
} 

function point(){ 
    leftP = parseInt(Math.random()*970); 
    topP = parseInt(Math.random()*580); 
    $points = $("<div class=point/>") 
    .css({"backgroundColor":"yellow","height":"10px","width":"10px","left":0, 
     "top":0,"position":"relative"}) 
    $('#wrapper').append($points) 
} 



function update(){ 
    //left 
    if(keyArray[65]){ 
     var newLeft = parseInt(player.left)-player.speed+"px" 
     player.left = newLeft; 
     document.getElementById(player.id).style.left = newLeft; 
    } 
    //right 
    if(keyArray[68]){ 
     var newLeft = parseInt(player.left)+player.speed+"px" 
     player.left = newLeft; 
     document.getElementById(player.id).style.left = newLeft; 
    } 
    //up 
    if(keyArray[87]){ 
     var newTop = parseInt(player.top)-player.speed+"px" 
     player.top = newTop; 
     document.getElementById(player.id).style.top = newTop; 
    } 
    //down 
    if(keyArray[83]){ 
     var newTop = parseInt(player.top)+player.speed+"px" 
     player.top = newTop; 
     document.getElementById(player.id).style.top = newTop; 
    } 

    //player2 
    //left 
    if(keyArray[37]){ 
     var newLeft = parseInt(player2.left)-player2.speed+"px" 
     player2.left = newLeft; 
     document.getElementById(player2.id).style.left = newLeft; 
    } 
    //right 
    if(keyArray[39]){ 
     var newLeft = parseInt(player2.left)+player2.speed+"px" 
     player2.left = newLeft; 
     document.getElementById(player2.id).style.left = newLeft; 
    } 
    //up 
    if(keyArray[38]){ 
     var newTop = parseInt(player2.top)-player2.speed+"px" 
     player2.top = newTop; 
     document.getElementById(player2.id).style.top = newTop; 
    } 
    //down 
    if(keyArray[40]){ 
     var newTop = parseInt(player2.top)+player2.speed+"px" 
     player2.top = newTop; 
     document.getElementById(player2.id).style.top = newTop; 
    } 
    blockade(); 
    requestAnimationFrame(update); 
} 

function blockade(){ 
    var elemLeft = parseInt($('#wrapper').css('left')); 
    var elemWidth = parseInt($('#wrapper').css('width')); 
    var elemTop= parseInt($('#wrapper').css('height')); 
    //blocks players from moving outside of game 
    if(parseInt(player.left) + player.width >= elemLeft+elemWidth){ 
     player.left = elemWidth - player.width - 2; 
    } 
    if(parseInt(player.top) + player.height >= elemTop){ 
     player.top = elemTop - player.height - 2; 
    } 
    if(parseInt(player.top) < 3){ 
     player.top = 3; 
    } 
    if(parseInt(player.left) < 3){ 
     player.left = 3; 
    } 
    if(parseInt(player2.left) + player2.width >= elemLeft+elemWidth){ 
     player2.left = elemWidth - player2.width - 2; 
    } 
    if(parseInt(player2.top) + player2.height >= elemTop){ 
     player2.top = elemTop - player2.height - 2; 
    } 
    if(parseInt(player2.top) < 3){ 
     player2.top = 3; 
    } 
    if(parseInt(player2.left) < 3){ 
     player2.left = 3; 
    } 
} 

window.onkeydown = function(page){ 
    keyArray[page.keyCode] = page.type === 'keydown'; 
} 
    window.onkeyup = function(page){ 
     keyArray[page.keyCode] = page.type === 'keydown' 
} 

CSS

html, body {margin: 0; height: 100%; overflow: hidden} 

#container{ 
    width:80%; 
    height:60%; 
    display: block; 
    text-align:center; 
    margin: 0 auto; 
} 
#wrapper{ 
    left:0px; 
    width:1000px; /* 100% */ 
    height:600px; 
    border:1px solid lime; 
    margin:0 auto; 
    background-color:black; 
} 

#player1, .point { 
    float: left; 
    clear: both; 
} 
body{ 
    background-color:black; 
} 
#waveNum{ 
    color:white; 
    font-size:200%; 
} 

.point { 
    overflow: auto;  
} 

所以目前我需要我的point()函數生成<div id="wrapper">它是內,但幾個不同的產卵後隨機DIV ,最終不會留在包裝div中。看起來像point()的容器似乎正在向下移動。產生的越多,容器底部和外部看起來越頻繁。

最後,我的想法是讓所有的人有那樣的相同的頂部和左側的原始位置,我可以用我的playerplayer2觸摸它們(比賽左邊和頂部位置),讓他們像消失正在收集他們像點。我也不能讓他們有相同的原點。我認爲這些問題可能與

回答

0

您可以使用,使出現特定的div

z-index: 0 
0

嘗試增加絕對定位到您的包裝股利和相對定位的div容器:

#container { 
    position: relative; 
} 

#wrapper { 
    position: absolute; 
    top: 0; 
    left: 0; 
} 

這將div從文檔的其餘部分中取出正常流。

請參閱here瞭解更多關於此原因的說明。