2012-04-01 48 views
0

ボタンをクリックしてdivを動的に作成し、親の名前「option_selection」に追加しようとしています。しかし、divは「消えた」(私​​は「不可視」と言って何か他のものを意味するかもしれないので、他に何が言えるのか分からない!)。ここで動的に作成されたDivが非表示になっています

は私のJSコードである:ここ

function addMoreOptions(div){ 
    var counter_div = document.getElementById("hidden"); 
    var counter = counter_div.value; 
    counter_div.setAttribute("id","not_hidden"); 
    counter_div.setAttribute("name","not_hidden"); 
    counter++; 
    var addString=""; 
    addString = addString+"<div style="\"width:" 250px;="" float:="" left;="" \"="">"; 
    addString = addString+"<p>Choose option type to display :</p></div>"; 
    addString = addString+"<div style="\"float:" left;\"=""><select id="\"option_type\"" name="\"option_type_";" addstring="addString+counter;"><option value="\"1\"">Single Option (radio button)</option>"; 
    addString = addString+"<option value="\"2\"">Multiple Option (check boxes)</option>"; 
    addString = addString+"<option value="\"3\"">Text Entry (text input box)</option>"; 
    addString = addString+"<option value="\"4\"">Menu(Drop Down)</option></select></div>"; 
    addString = addString+"<div style="\"float:" none;="" clear:="" both;="" width:="" 0px;\"=""></div>"; 
    addString = addString+"<div style="\"width:" 250px;="" float:="" left;="" \"="">"; 
    addString = addString+"<p>Enter option text:</p></div><div style="\"float:" left;\"="">"; 
    addString = addString+"<input type="\"text\"" id="\"option_text_1\"" name="\"option_text_";" addstring="addString+counter;"><input id="\"hidden\"" type="\"hidden\"" name="\"hidden\"" value=""; 
    addString = addString+counter; 
    addString = addString+""></div><div style="\"float:" none;="" clear:="" both;="" width:="" 0px;\"=""></div>"; 
    var element = document.createElement("div"); 
    element.innerHTML= addString; 
    document.getElementById(div).appendChild(element); 
    alert(document.getElementById(div).innerHTML); 
} 

は、HTMLコードが

ある
 <div id="option_selection"> 
      <div> 
       <div style="width: 250px; float: left; "><p>Choose option type to display :</p></div> 
       <div style="float: left;"> 
        <select id="option_type" name="option_type_1"> 
         <option value="1">Single Option (radio button)</option> 
         <option value="2">Multiple Option (check boxes)</option> 
         <option value="3">Text Entry (text input box)</option> 
         <option value="4">Menu(Drop Down)</option> 
        </select> 
       </div> 
       <div style="float: none; clear: both; width: 0px;"></div> 
       <div style="width: 250px; float: left; "><p>Enter option text:</p></div> 
       <div style="float: left;"> 
        <input type="text" id="option_text_1" name="option_text_1"> 
        <input id="hidden" name="hidden" type="hidden" value="1">        
       </div> 
       <div style="float: none; clear: both; width: 0px;"></div> 
      </div>      
     </div>     
     <div align="right" style="width: 800px;"> 
      <button id="add" onclick="addMoreOptions('option_selection')">Add More Option</button> 

すべてのヘルプは高く評価されるだろう。 ありがとうございました。

+2

リンクの腐敗を防ぐために、stackoverflowにコードを追加してください。 – max

+0

関連するコードを作成してください。 – PeeHaa

+0

申し訳ありませんが、私はあなたの2人が言ったことを得ることができませんでした:( – Potheek

答えて

1

あなたbuttonにはtype -attributeを持っていません。デフォルトのボタンタイプはsubmithereも参照)です。

タイプ
ボタンの種類。可能な値は次のとおりです。
- submit:ボタンはフォームデータをサーバーに送信します。 属性が指定されていない場合は、、または属性が空の値または無効な値に動的に変更された場合の既定値です。
- リセット:このボタンは、すべてのコントロールを初期値にリセットします。
- ボタン:このボタンにはデフォルトの動作はありません。イベントの発生時にトリガされる、要素のイベントに関連付けられたクライアント側のスクリプトを持つことができます。

を追加してクリックすると、フォームは送信されません。

<button type="button" id="add" onclick="addMoreOptions('option_selection')">Add More Option</button> 
+0

ありがとうございました。それは分かりません。 – Potheek

0

使用

document.getElementById(div).innerHTML = element; 

代わりの

document.getElementById(div).appendChild(element); 
+0

さて、私はそれを試みましたが、うまくいきませんでした。さらに、私はそれがHTMLコードにOBJECTを追加しようとすると動作しないと思います。 – Potheek

+0

大丈夫私は答えを得たと思います。私が追加ボタンを押している間、スクリプトは実際にdivを追加していますが、フォームを提出する(これはかなり奇妙です!ボタンが質問を出す理由を知りたがっています!!!)。関数呼び出しの後に "return false;"を追加すると、問題は解決します – Potheek

関連する問題