1

所以,我基本上需要做标题所说的,用按钮动态添加表单元素到表单中。

我目前有一个由按钮加载的表单。此表单位于 jQuery 弹出框内。我目前在此表单下方有一个按钮,每次都应向表单添加一些元素。此按钮当前不起作用,我真的不确定如何执行此操作。

这是我每次都需要添加的内容,格式如下:

Question [text-box]       Dummy 1 [text-box]
                          Dummy 2 [text-box]
                          Dummy 3 [text-box]
                          Correct [text-box]
                          [delete-button]

基本上,将添加一个新问题,以及旁边的另外 4 个文本框用于错误答案和一个正确答案。它们下方还必须有一个删除按钮才能完全删除该问题。稍后我将添加所有功能,尽管我需要动态添加和删除工作。

这是我目前拥有的:

function addNewQuizField()
{
    var counter = 1;
    var limit = 10;
    var quizForm = document.getElementById('newQuizForm');

    if (counter == limit)  
    {
          alert("You have reached the limit of adding " + counter + " questions");
     }
     else 
     {
          var newQuest = document.createElement('div');
          newQuest.innerHTML = "Entry " + (counter + 1) + " <br><input type='text' name='myInputs[]'>";
          document.getElementById(quizForm).appendChild(newQuest);
          counter++;
     }
}

这是我创建测验表格的函数(我知道很乱):

function createQuizForm()
{
    var quizForm = '<form name="editForm" id="newQuizForm" method="post" action="createplay.php"><input type=hidden id="dialogid" name="dialogid" value=""><input type=hidden id="dialogtype" name="dialogtype" value=""><input type=hidden id="uid" name="uid" value="<?php echo $userid; ?>"><div>Quiz Name: <input type="text" id="nameEdit" name="nameEdit" value=""></div><div>Embed Code: <textarea id="textEdit" name="textEdit" row="10" cols="50"></textarea></div><input type="submit" class="roundButton upload" value="" /><input name="addNewField" type="button" onClick="addNewQuizField();" /></form>';

    var dialogDiv = document.getElementById('dialog');

    dialogDiv.innerHTML = quizForm;

    OpenNewQuizDialog();
}

非常感谢所有帮助!

4

1 回答 1

1

这是您正在寻找当前代码的内容吗?检查这个plunk

于 2013-08-13T10:59:52.427 回答