js中创建form表单

有的时候需要在js中创建form向controller提交数据,下面是在工作中遇到的一些问题和解决办法:

简单的用jquery创建form:

var form  = $("<form method = 'post'></form>");
var input = $("<input type='hidden' name='name' value="+data+">");
form.append(input);
form.submit;

函数封装提交:

function StandardPost (url,args) 
{
    var form = $("<form method='post'></form>");
    form.attr({"action":url});
    for (arg in args)
    {
        var input = $("<input type='hidden'>");
        input.attr({"name":arg});
        input.val(args[arg]);
        form.append(input);
    }
    form.submit();
} 

其中args为格式:{key:value,key1:valye2…},可以一个参数一个参数传,也可以直接传一个jsonString, 在controller中再转化为map,个人更喜欢后一种方法,直接用json的序列化工具(jsonmapper之类),反序列为map,再取值。

上面两种都是jquery创建form,在chrome下可正常使用,但是在firefox下不行,百度之,发现原因是:
经过研究发现,FireFox在提交页面表单时要求页面有完整的标签项,即<html><head><title></title></head><body><form></form</body</html>这样的标签结构

解决方法很简答,给把新建的form添加到一个现存节点即可。
上面的函数修改后代码如下:

function StandardPost (url,args) 
{
    var form = $("<form method='post'></form>");
    form.attr({"action":url});
    for (arg in args)
    {
        var input = $("<input type='hidden'>");
        input.attr({"name":arg});
        input.val(args[arg]);
        form.append(input);
    }
    $("#someid").append(form);
    form.submit();
} 

另外还有一个问题,就是关于提交数据后是从本页面跳转还是新打开页面
可参见: http://blog.youkuaiyun.com/natian306/article/details/21527369

### 使用 JavaScript 动态创建 HTML 表单并根据后台返回数据更新 当需要基于后端响应来构建或调整前端表单时,可以利用 JavaScript 来动态生成这些元素。下面展示了一个具体的例子,说明如何通过 AJAX 请求获取服务器反馈,并据此创建新的 `<form>` 元素。 #### 发送AJAX请求并与服务器交互 为了能够接收到服务端传回的信息,在发起网络调用之前先定义好回调函数用于处理成功的响应: ```javascript function createFormBasedOnResponse() { $.ajax({ type: "GET", url: "/getFormData", // 假设这是用来取得表单配置信息的API接口地址 success: function(response){ buildDynamicForm(response); }, error: function(xhr, status, error){ console.error('Error fetching form data:', xhr.responseText); } }); } ``` 一旦获得了来自服务器的有效 JSON 对象作为回应,则可继续执行下一步骤——即实际建立所需的表单结构[^2]。 #### 构建动态表单 接下来编写 `buildDynamicForm` 函数负责解析上述提到的服务端提供的JSON对象,并依此组装出相应的HTML标记字符串;最后将其插入页面DOM树中适当位置显示出来供用户填写: ```javascript function buildDynamicForm(formData) { let formContainer = document.createElement("div"); const formElement = document.createElement("form"); formElement.setAttribute("method", formData.method || 'POST'); formElement.setAttribute("action", formData.actionUrl); Object.keys(formData.fields).forEach(function(key) { let fieldConfig = formData.fields[key]; let labelElm = document.createElement("label"); labelElm.htmlFor = key; labelElm.textContent = fieldConfig.label; let inputElm = document.createElement(fieldConfig.type === 'textarea' ? "textarea" : "input"); inputElm.id = key; inputElm.name = key; if (fieldConfig.placeholder) { inputElm.placeholder = fieldConfig.placeholder; } formElement.appendChild(labelElm); formElement.appendChild(inputElm); formElement.appendChild(document.createElement("br")); // 添加换行符以便布局美观 if (fieldConfig.required && typeof fieldConfig.required !== undefined) { inputElm.required = true; } }); let submitButton = document.createElement("button"); submitButton.type = "submit"; submitButton.textContent = "Submit"; formElement.appendChild(submitButton); formContainer.appendChild(formElement); document.body.insertBefore(formContainer, document.body.firstChild); // 将新创建好的表单位置于body最前面 } ``` 这段代码展示了怎样依据从服务器得到的数据模型去构造一个完整的HTML表单实例[^1]。值得注意的是这里假设了服务端会提供有关字段名称、标签文字以及其他属性在内的必要细节给客户端应用逻辑使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值