首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > JavaScript >

用JS创建form在FireFox中不能提交的有关问题

2013-01-23 
用JS创建form在FireFox中不能提交的问题在一个前端页面上,需要通过JavaScript来提交参数,使用JS创建form表

用JS创建form在FireFox中不能提交的问题
在一个前端页面上,需要通过JavaScript来提交参数,使用JS创建form表单,将参数append到表单中进行提交,代码如下:Js代码:  

  1. function loadConfig(gameUrl,skinId){  
  2.                 var temp = document.createElement("form");  
  3.                 temp.action = "${createLink(controller:'mobileConfig', action:'beforeLaunchConfig')}";          
  4.                 temp.method = "POST";  
  5.                 temp.style.visibility="hidden";  
  6.                 var opt = document.createElement("input");  
  7.                 opt.name = "gameUrl";  
  8.                 opt.id = "gameUrl";  
  9.                 opt.value = gameUrl;  
  10.                 var opt2 = document.createElement("input");  
  11.                 opt2.name = "skinId";  
  12.                 opt2.id = "skinId";  
  13.                 opt2.value = skinId;  
  14.                 temp.appendChild(opt);  
  15.                 temp.appendChild(opt2);  
  16.                 temp.submit();  
  17.             }  

 该功能在Chrome及Safari上都能成功运行,但在使用FireFox(17.0.1)时不能成功提交,经过研究发现,FireFox在提交页面表单时要求页面有完整的标签项,即<html><head><title></title></head><body><form></form</body</html>这样的标签结构。因此,将该段JS做了写小改动:

Js代码:  
  1. function loadConfig(gameUrl,skinId){  
  2.                 var pageDiv = document.getElementById("page");  
  3.                 var temp = document.createElement("form");  
  4.                 temp.action = "${createLink(controller:'mobileConfig', action:'beforeLaunchConfig')}";          
  5.                 temp.method = "POST";  
  6.                 temp.style.visibility="hidden";  
  7.                 temp.name = "loadConfigPage";  
  8.                 var opt = document.createElement("input");  
  9.                 opt.name = "gameUrl";  
  10.                 opt.id = "gameUrl";  
  11.                 opt.value = gameUrl;  
  12.                 var opt2 = document.createElement("input");  
  13.                 opt2.name = "skinId";  
  14.                 opt2.id = "skinId";  
  15.                 opt2.value = skinId;  
  16.                 temp.appendChild(opt);  
  17.                 temp.appendChild(opt2);  
  18.                 pageDiv.appendChild(temp);  
  19.                 temp.submit();  
  20.             }  

 在<body>标签内append此处创建的form表单,再进行提交就能成功了。参考博文:http://bytes.com/topic/javascript/answers/542837-document-getelementbyid-myform-submit-does-not-work

热点排行