dijit / form / form在firefox中发布POST问题

时间:2013-07-31 14:29:31

标签: forms dojo submit

我正在尝试使用dojo.xhrPost发布表单。下面的代码在chrome中运行良好但在Firefox中根本不起作用。当我说它不起作用时,我看到该页面再次重新加载,没有任何反应。我尝试使用dojo.stopEvent(event);,但似乎无法在Firefox中使用。

你能告诉我可能是我的错误。我觉得问题更多的是形式而不是xhrPost。

HTML如下所示:

<div data-dojo-type="dijit/form/Form" data-dojo-id="myform" id="loginform" 
encType="multipart/form-data" action="" method="post">
<script type="dojo/method" data-dojo-event="onSubmit">
    if(this.validate()){
        senddata();  //calling the javascript function
    }else{
        alert('Form contains invalid data.  Please correct first');
        return false;
    }
    return true;
 </script>
  <table cellspacing="10">
  <tr>
  <td><label for="name">Username:</label></td>
  <td><input type="text" id="username" name="username" 
  required="true" placeholder="Your UserName" data-dojo-
  type="dijit.form.ValidationTextBox"/></td>
  </tr>
  <tr>
  <td><label for="password">Password:</label></td>
  <td><input type="password" id="password" name="password"       
  required="true" placeholder="Your Password" 
  data-dojotype="dijit.form.ValidationTextBox"/></td>
  </tr>
 </table>
 <div id="response" style="float: right"></div>
 <button data-dojo-type="dijit.form.Button" type="submit" name="submitButton" 
    value="Submit" style="float: right;">Submit</button>
 </div>

我的Javascript代码如下:

function senddata(){
dojo.stopEvent(event);

obj = {};
obj.user_name =dijit.byId("username").get("value");
obj.password =dijit.byId("password").get("value");

var xhrArgs = {
          url: "./script/php/validatelogin.php",
          postData: obj,
          handleAs: "json",
          load: function(data){
              //alert('success');
              if(data.success==true){
                  window.location = data.message;
                  dojo.byId("response").innerHTML = "Form posted.";  
              }else{
                  dojo.byId("response").innerHTML = "login Failed";
              }

          },
          error: function(error){
             console.log("error occured!!!");
             dojo.byId("response").innerHTML = "Failed to Post the Form..";
                }
          };


//alert('starting');
 var deferred = dojo.xhrPost(xhrArgs);
 //alert('done');

 return false;

}

1 个答案:

答案 0 :(得分:0)

首先,将data-dojo-type更改为路径格式。例如:dijit/form/ValidationTextBox

其次,在data-dojo-type的密码字段中修正您的输入错误。您输入了data-dojotype,在'dojo'和&amp;之间错过了- b = '类型'

关于dojo.byId()&amp;的更多information dijit.byId()。

结果如下:

    <div data-dojo-type="dijit/form/Form" data-dojo-id="myform" id="loginform" encType="multipart/form-data" action="" method="post">
    <script type="dojo/method" data-dojo-event="onSubmit">
        if(this.validate()){
            senddata();  //calling the javascript function
        }else{
            alert('Form contains invalid data.  Please correct first');
            return false;
        }
        return true;
    </script>

    <table cellspacing="10">
        <tr>
            <td><label for="name">Username:</label></td>
            <td><input type="text" id="username" name="username" required="true" placeholder="Your UserName" data-dojo-type="dijit/form/ValidationTextBox" /></td>
        </tr>
        <tr>
            <td><label for="password">Password:</label></td>
            <td><input type="password" id="password" name="password" required="true" placeholder="Your Password" data-dojo-type="dijit/form/ValidationTextBox" /></td>
        </tr>
    </table>
    <div id="response" style="float: right"></div>
    <button data-dojo-type="dijit/form/Button" type="submit" name="submitButton" value="Submit" style="float: right;">Submit</button>
</div>

<script>
function senddata(){
    dojo.stopEvent(event);

    obj = {};
    obj.user_name =dijit.byId("username").get("value");
    obj.password =dijit.byId("password").get("value");

    var xhrArgs = {
        url: "./script/php/validatelogin.php",
        postData: obj,
        handleAs: "json",
        load: function(data){
            //alert('success');
            if(data.success==true){
                window.location = data.message;
                dojo.byId("response").innerHTML = "Form posted.";  
            }else{
                dojo.byId("response").innerHTML = "login Failed";
            }
        },
        error: function(error){
            console.log("error occured!!!");
            dojo.byId("response").innerHTML = "Failed to Post the Form..";
        }
    };
    //alert('starting');
    var deferred = dojo.xhrPost(xhrArgs);
    //alert('done');
    return false;
}
</script>