4

如何使用 sencha touch 与数据库建立远程连接我的意思是,如何将表单提交到远程数据库?您如何从数据库中获得您的表单已成功提交的响应?

4

1 回答 1

4

您可以通过提出Ext.Ajax请求来做到这一点。

假设您的表单有 3 个字段:-

  • 姓名 ( textfield)
  • 密码 ( passwordfield)
  • 年龄 ( numberfield)

您将获得如下所示的字段值,

.....
.....
// form code ...
{
  xtype:'button',
  id:'submitBtn',
  text:'Submit',
  ui:'confirm',
  listeners : {
         tap : function() {
                var form = Ext.getCmp('form-id');
                var values = form.getValues();
                Ext.Ajax.request({
                      url: 'http://www.servername.com/insert.php',
                      params: values,

                      success: function(response){
                          var text = response.responseText;
                          Ext.Msg.alert('Success', text);
                     }

                     failure : function(response) {
                           Ext.Msg.alert('Error','Error while submitting the form');
                           console.log(response.responseText);
                     }
              });
         }
   }  
....
....

现在,在服务器端,您的insert.php代码将与您的数据库建立连接并插入值并将响应返回给用户。

<?php 
$con = mysql_connect("server","username","password");
mysql_select_db('database_name',$con);

$insertQry = "INSERT INTO tableName(name,password,age) VALUES ('".$_POST['name']."','".$_POST['password']."','".$_POST['age']."')";

if(mysql_query($insertQry))
{
    echo('success');
}
else 
{
    echo('failure' . mysql_error());
}
?>
于 2012-04-30T12:24:43.123 回答