extJs常用之季种Ajax异步提交

extJs常用之季种植Ajax异步提交

 在action中输出的办法为:

HttpServletResponse
response=ServletActionContext.getResponse();

response.setContentType(“text/html”);

response.setCharacterEncoding(“UTF-8”);

response.getWriter().print(“宗龙龙!”);或者response.getWriter().write(“宗龙龙!”);
response.getWriter().flush();
response.getWriter().close();

使非写response.getWriter().flush(); 
response.getWriter().close();或者

 

/**
 * 第一种Ajax提交方式
 * 这种方法需要一直使用ext Ajax方法进行付出
 * 使用这种艺术,需要将急需传递的参数进行包装
 * @return
 */
function saveUser_ajaxSubmit1() {
 Ext.Ajax.request( {
  url : ‘user_save.action’,
  method : ‘post’,
  params : {
   userName : document.getElementById(‘userName’).value,
   password : document.getElementById(‘password’).value
  },
  success : function(response, options) {
   var o = Ext.util.JSON.decode(response.responseText);
   alert(o.msg);
  },
  failure : function() {
  }
 });
}
/**
 * 第二种Ajax提交方式
 * 这种艺术以为ext的ajax指定一个html表单
 * 使用这种办法,不欲拿需传递的参数进行包装
 * 
 * @return
 */
function saveUser_ajaxSubmit2() {
 Ext.Ajax.request( {
  url : ‘user_save.action’,
  method : ‘post’,
  form : ‘userForm’, // 指定表单
  success : function(response, options) {
   var o = Ext.util.JSON.decode(response.responseText);
   alert(o.msg);
  },
  failure : function() {
  }
 });
}
/**
 * 第三种Ajax提交方式
 * 这种办法以为ext的亲善之表单进行付出
 * 使用这种方法,需要使用ext自己之textField组件
 * 
 * @return
 */
function saveUser_ajaxSubmit3() {
 // 定义表单
 var formPanel = new Ext.FormPanel( {
  labelWidth : 75,
  frame : true,
  bodyStyle : ‘padding:5px 5px 0’,
  width : 350,
  defaults : {
   width : 230
  },
  defaultType : ‘textfield’,
  items : [ {
   fieldLabel : ‘用户名’,
   name : ‘userName’,
   allowBlank : false
  }, {
   fieldLabel : ‘密   码’,
   name : ‘password’
  } ]
 });
 // 定义窗口
 var win = new Ext.Window( {
  title : ‘添加用户’,
  layout : ‘fit’,
  width : 500,
  height : 300,
  closeAction : ‘close’,
  closable : false,
  plain : true,
  items : formPanel,
  buttons : [ {
   text : ‘确定’,
   handler : function() {
    var form = formPanel.getForm();
    var userName = form.findField(‘userName’).getValue().trim();
    var password = form.findField(‘password’).getValue().trim();
    if (!userName) {
     alert(‘用户名不可知吧空’);
     return;
    }
    if (!password) {
     alert(‘密码不克为空’);
     return;
    }
    form.submit( {
     waitTitle : ‘请稍后…’,
     waitMsg : ‘正在保存用户信息,请稍后…’,
     url : ‘user_save.action’,
     method : ‘post’,
     success : function(form, action) {
      alert(action.result.msg);
     },
     failure : function(form, action) {
      alert(action.result.msg);
     }
    });
   }
  }, {
   text : ‘取消’,
   handler : function() {
    win.close();
   }
  } ]
 });
 win.show();
}
/**
 * 第四栽Ajax提交方式
 * 这种措施以html的表单转化为ext的表单进行异步提交
 * 使用这种方法,需要定义好html的表单
 * 
 * @return
 */
function saveUser_ajaxSubmit4() {
 new Ext.form.BasicForm(‘userForm’).submit( {
  waitTitle : ‘请稍后…’,
  waitMsg : ‘正在保存用户信息,请稍后…’,
  url : ‘user_save.action’,
  method : ‘post’,
  success : function(form, action) {
   alert(action.result.msg);
  },
  failure : function(form, action) {
   alert(action.result.msg);
  }
 });
}

相关文章