【问题标题】:JQuery ".html()" method with the <option> tag带有 <option> 标记的 JQuery ".html()" 方法
【发布时间】:2012-03-07 02:34:51
【问题描述】:

我正在尝试使用 JQuery 格式化表单,编辑 div 的 html。

假设html文件的相关部分如下:

<div id="genForm">
</div>

在这种形式中,我必须使用“选择”输入。

以下 jQuery 代码可以正常运行:

$("#genForm").html("<form action=\"apply.php\" method=\"post\"><select></select></form>")

但是,在添加&lt;option&gt;标签的那一刻,如下:

$("#genForm").html("<form action=\"apply.php\" method=\"post\"><select><option></option></select></form>")

代码完全中断并拒绝编辑 HTML,留下一个空的&lt;div&gt;

我完全不知道为什么会这样。请指教。

【问题讨论】:

标签: javascript jquery forms option


【解决方案1】:

查看http://jsfiddle.net/pratik136/kTGAe/

代码对我来说似乎可以正常工作。

【讨论】:

  • 我意识到问题正在发生,因为我试图编辑表格中的 html,而不是 div,正如我在问题中所说的不准确。但是,我很困惑为什么这会有所不同-您知道为什么 JQuery 无法将选项标记写入表吗?编辑:澄清一下,如果 html 文件中的唯一元素是表格,则该示例似乎有效,但在扩展场景中不起作用 - 尽管我的代码中没有任何内容会影响表格标签。
  • 我仍然没有看到问题:jsfiddle.net/pratik136/kTGAe 我已经输入了 3 个案例,我认为这些案例代表了您的问题域。
【解决方案2】:

我将假设您有一些额外的代码不会显示,因此您最好的办法是尝试拆分所有内容。

var _form = $("<form action=\"apply.php\" method=\"post\"></form>");
var _sel = $("<select name='selectName'></select>");

_sel.append("<option value='0'>Select</option>");
_sel.append("<option value='1'>It's me</option>");
_sel.append("<option value='2'>Again</option>");
_form.append(_sel);

$("#genForm").append(_form); // or use .html() alternatively.

jQuery 将创建节点。 jQuery 无所不知。

编辑:刚刚添加了 jsFiddle 链接(哇,这东西太酷了!)

http://jsfiddle.net/QpQHN/4/

【讨论】:

猜你喜欢
  • 1970-01-01
  • 2012-01-13
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-07-14
  • 1970-01-01
相关资源
最近更新 更多