2016-12-03 15 views
0

JavaScriptで動的入力を作成しています。しかし、私は入力の幅の問題を処理できませんでした。入力はユーザーの選択に応じて作成されます。 (4行6列のように)私はページのdivの中心を持っています。
私はそれが欲しいです:どのように多くの列が作成されても、そのdivで幅を固定する必要があります。つまり、それぞれ4列とwidth:50pxがある場合、5列が作成されたときは40pxでなければなりません。動力学的に作成された入力についての問題

Here is the same problemですが、それは私のためには機能しません。

そして、これは私のコードです:

function HideHider() { 
 
    var hider = document.getElementById("hiderPanel"); 
 
    var satir = document.getElementById("satir").value; 
 
    var sutun = document.getElementById("sutun").value; 
 
    var area = document.getElementById("inputArea"); 
 
    var w = 100/sutun; 
 

 
    for (i = 0; i < satir; i++) { 
 
     var newdiv = document.createElement("div"); 
 
     newdiv.setAttribute("class", "satirdiv"); 
 
     newdiv.setAttribute("id", "satir" + i + 1); 
 
     area.appendChild(newdiv); 
 
    } 
 

 
    for (i = 0; i < satir; i++) { 
 
     for (j = 0; j < sutun; j++) { 
 
      var newinput = document.createElement("input"); 
 
      var gecici = document.getElementById("satir" + i + 1); 
 
      newinput.type = "text"; 
 
      newinput.setAttribute("id", "input" + (satir + 1) + "_" + (sutun + 1)); 
 
      gecici.appendChild(newinput); 
 
     } 
 
    } 
 

 
    hider.style.display = 'none'; 
 
}
.hider 
 
{ 
 
    display:block; 
 
    position:fixed; 
 
    top:0; 
 
    left:0;  
 
    height:100%; 
 
    width:100%; 
 
    z-index:15;  
 
    background: rgba(64, 64, 64, 0.5); 
 
    opacity:0.9; 
 
} 
 

 
.inputpanel 
 
{ 
 
    margin-left:auto; 
 
    margin-right:auto; 
 
    box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.3); 
 
    background-color: #F7F7F7;  
 
    padding:40px; 
 
    width:300px; 
 
    height:350px; 
 
} 
 

 
.btndiv 
 
{ 
 
    margin-top:30%; height:40px; 
 
} 
 

 
.btndiv button 
 
{ 
 
    text-align:center; 
 
    color:white; 
 
    width:100%; 
 
    height:100%; 
 
    background-color:#008CBA; 
 
    box-shadow: 0 8px 16px 0 rgba(0,0,0,0.2), 0 6px 20px 0 rgba(0,0,0,0.19); 
 
    border-radius: 8px; 
 
} 
 

 
.satirdiv 
 
{ 
 
    display:table; 
 
    width:100%;  
 
} 
 

 
.satirdiv input 
 
{ 
 
    display:table-cell; 
 
    width:auto; 
 
}
<div id="hiderPanel" class="hider"> 
 
    <div class="inputpanel"> 
 
     <div style="float:left; margin-top:3%; width:100%;"> 
 
      <label style="float:left; width:30%;">Satir Sayisi:</label> 
 
      <input type="number" id="satir" /> 
 
     </div> 
 
     <div style="float:left; margin-top:3%; width:100%;"> 
 
      <label style="float:left; width:30%;">Sutun Sayisi:</label> 
 
      <input type="number" id="sutun" /> 
 
     </div> 
 
     <div class="btndiv"> 
 
      <button onclick="HideHider()">Devam</button> 
 
     </div> 
 
    </div> 
 
</div> 
 

 
<div id="inputArea" style="margin-left:auto; margin-top:10%; margin-right:auto; width:50%; background-color:red;"> 
 
</div>

答えて

0

私は問題を解決してきました。入力用のdivを作成しました。そしてそれらを表示した:テーブルセル;みんな、ありがとう。

関連する問題