首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用Javascript而不是POSTing添加的HTML表单HIdden字段

使用Javascript而不是POSTing添加的HTML表单HIdden字段
EN

Stack Overflow用户
提问于 2010-05-18 12:51:41
回答 3查看 7.4K关注 0票数 11

我有一个表单,用户可以在其中输入链接,单击“添加链接”按钮,然后(通过jQuery)将该链接作为隐藏字段添加到表单中。问题是,当我提交表单时,它不是POSTing。这真的开始让我感到困惑了。问题是,如果我将一个隐藏字段硬编码到表单中,它会被posted,但我的函数由于某种原因无法工作。隐藏字段确实被添加到我的表单中,正如我在Firebug中看到的那样,但它只是没有与POST数据一起发送。

需要注意的是,我在Javascript中使用了一个数组来保存元素,直到表单被提交,它还会以可见的方式发布这些元素,让用户看到他们添加了什么。我在元素的"name“字段上使用[]表示法,因为我希望将链接提供给PHP中的数组。

下面是链接创建,它被附加到我的表单中:

代码语言:javascript
运行
复制
        function make_hidden_element_tag(item_type, item_content, item_id)
{
    return '<input type="hidden" name="' + item_type + '[]" id="hidden_link_' + item_id + '" value="' + item_content + '"/>';

有没有人知道为什么这篇文章不能发布。如上所述,任何与上面几乎相同的硬编码标签都工作得很好,只是这个标签不起作用。下面是我如何使用jQUery将标记添加到表单中:

代码语言:javascript
运行
复制
$('#link_td').append( make_hidden_element_tag('links', link, link_array.length - 1));

我使用的是Kohana 3框架,尽管我不确定这对此有什么影响,因为从HTML添加到页面并按下submit按钮之后,它实际上并没有做任何事情。

EN

Stack Overflow用户

发布于 2010-05-18 13:23:41

如果数据没有发送到服务器,那么输入元素肯定不会添加到表单中。

在表单提交前尝试执行以下代码:

代码语言:javascript
运行
复制
<form onsubmit="return doBeforeSubmit(this);"> ... </form>

函数是..。

代码语言:javascript
运行
复制
function doBeforeSubmit(form)
{
   var es = form.elements;
   var l = es.length;

   var msgs = [];

   for(var idx = 0; idx < l; idx++)
   {
      var e = es[idx];
      msgs.push('name=' + e.name + ', type=' + e.type + ', value=' + e.value;
   }

   alert(msgs.join('\n'));
   return false;
}

如果你没有得到你的字段,那么“输入”就不会被添加到表单中,而是被添加到其他地方。

如果你真的得到了这个领域...我们需要更深入地挖掘。

票数 5
EN
查看全部 3 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2854640

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档