2014-01-18 33 views
0

我在网页中重复使用javascript函数。我以相同的形式以两种不同的方式使用它。第一个绑定到输入字段的onChange,它工作正常。第二个是在窗体结尾处按钮的onClick。这里就是打开表单Javascript不能与onClick搭配使用

<form method="POST" action="new_emissions.php?action=<?php echo $action;?>" 
id="emissionsform" enctype="multipart/form-data"> 

我会发布整个事情,但它变得有点长,不想烦你用的东西,工作。 这是的onChange它的工作原理

<td><input type="text" size=6 value="<?php echo $orno; ?>" name="orno" 
id="orno"onChange="fLookup('orno', '<? echo $fileQuadJ; ?>', '<? echo $fileQuadO; ?>', '<? echo $fileQuadZ; ?>')"></td> 

而这正是它不

<input type="submit" value="Save" 
onClick="fLookup('all', '<? echo $fileQuadJ; ?>', '<? echo $fileQuadO; ?>', '<? echo $fileQuadZ; ?>')"> 

的的onChange和的onClick都是相同的窗体上的按钮。
这是JS函数的第一部分。它在http.status和http.readyState的if语句中失败。检查控制台的这两个,当onChange被调用时,一切看起来都很好,所有内容都可以正常工作。 onClick失败,因为http.status不是200. console显示为0.我无法弄清楚为什么onChange和onClick之间的处理方式会有所不同。我已经将onChange的JS函数复制并粘贴到onClick,但仍然没有任何结果。

function fLookup(field, quadJ, quadO, quadZ) { 
var sendData = ''; 
sendData = sendData + '&cins='+document.getElementById('cins').value; 
if(field == 'eser' || field == 'all') 
    sendData = sendData+'&eser='+document.getElementById('eser').value; 
if(field == 'orno' || field == 'all') 
    sendData = sendData+'&orno='+document.getElementById('orno').value; 
if(field == 'emno' || field == 'all') 
    sendData = sendData+'&emno='+document.getElementById('emno').value; 
if(field == 'ddat' || field == 'all') 
    sendData = sendData+'&ddat='+document.getElementById('ddat').value; 
if((field == 'cdat1' || field == 'all') && document.getElementById('cdat1')) 
    sendData = sendData+'&cdat1='+document.getElementById('cdat1').value; 
if((field == 'cdat2' || field == 'all') && document.getElementById('cdat2')) 
    sendData = sendData+'&cdat2='+document.getElementById('cdat2').value; 
if((field == 'cdat3' || field == 'all') && document.getElementById('cdat3')) 
    sendData = sendData+'&cdat3='+document.getElementById('cdat3').value; 
if((field == 'cdat4' || field == 'all') && document.getElementById('cdat4')) 
    sendData = sendData+'&cdat4='+document.getElementById('cdat4').value; 
if((field == 'cdat5' || field == 'all') && document.getElementById('cdat5')) 
    sendData = sendData+'&cdat5='+document.getElementById('cdat5').value; 
if((field == 'cdat6' || field == 'all') && document.getElementById('cdat6')) 
    sendData = sendData+'&cdat6='+document.getElementById('cdat6').value; 
if(quadJ == '1') 
    sendData = sendData + '&checkJ=1'; 
if(quadO == '1') 
    sendData = sendData + '&checkO=1'; 
if(quadZ == '1') 
    sendData = sendData + '&checkZ=1'; 

sendData = sendData + '&field='+field; 
sendData = sendData + '&type=fLookup'; 

//alert(sendData); 
http.abort(); 
http.open('post','emissionValidate.php'); 
http.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); 
http.send(sendData); 
http.onreadystatechange = function() 
{ 
    console.log(http.readyState, http.status, sendData); 
    if(http.readyState == 4 && http.status == 200) 
    { 

任何帮助或输入是非常感谢。另外,如果我对数据轻松,请让我知道。提前致谢!

+0

一个较短的版本,为什么你的onclick使用在一个形式提交?你不能使用isset吗?您当前的提交按钮是否触发了您的表单操作?当你点击你的提交按钮时,它会去new_emissions.php?action = <?php echo $ action;?> – Bowenac

+0

和任何新闻用户3210302? – mplungjan

+0

@Bowenac它应该将信息发回到new_emissions.php。在这一点上,我会在我的提交按钮上解决POST问题,以防止出现问题。我提出了更新mplungjan的建议,但我开始怀疑我的FTP是否无法正常工作,因为它看起来没有变化。再次感谢您花时间浏览这些内容。对此,我真的非常感激! – user3210302

回答

1
  1. 从未使用onclick上一个提交按钮
  2. 记得返回false阻止提交
  3. 您sendata串联真的不是非常有效或可读

变化

<input type="submit" value="Save" 
onClick="fLookup('all', '<? echo $fileQuadJ; ?>', '<? echo $fileQuadO; ?>', '<? echo $fileQuadZ; ?>')"> 

<form onsubmit="return fLookup('all', '<? echo $fileQuadJ; ?>', '<? echo $fileQuadO; ?>', '<? echo $fileQuadZ; ?>')"> 
... 
<input type="submit" value="Save"/> 
</form> 

和fLookup结束与return false;

这里的功能是你的功能代码

var sendData = 'field='+field + '&type=fLookup' + '&cins='+document.getElementById('cins').value; 
if(quadJ == '1') sendData += '&checkJ=1'; 
if(quadO == '1') sendData += '&checkO=1'; 
if(quadZ == '1') sendData += '&checkZ=1'; 

var fields = ["eser","orno","emno","ddat"]; 
for (var i=1;i<=6;i++) if (document.getElementById('cdat'+i)) fields.push('cdat'+i); 
for (var i=0;i<fields.length;i++) { 
    var theField = fields[i]; 
    if (field ==="all" || field===theField) { 
     sendData+="&"+theField+"="+document.getElementById(theField).value; 
    } 
} 
+0

谢谢你的回复。我是一个刚刚起步的程序员,所以我现在的代码只是别人构建的其他页面的组合。我现在要更新代码。我会很快回复 – user3210302

+0

记住强制返回false作为函数中的最后一个语句,否则表单会干扰ajax。还要将.send移到onreadystate赋值后 – mplungjan

+0

好的,我已经对@mplungjan进行了修改。尝试发布时,我仍然遇到错误。我添加了返回false;到fLookup()就在submit语句的正下方。我会上传一张图片,但我不确定如何添加错误的屏幕截图。 这里是图片的链接。 http://screencast.com/t/dw663xVb最上面的POST来自一个onchange调用。第二个来自提交按钮。 – user3210302