相同点:都属于Ajax提交方式!
不同点:Ext.Ajax.request是Ext.data.connection的一个实例
form1.getForm().submit是BasicForm的一个实现方式
使用上的区别:
1.form1.getForm().submit常用在表单提交的时候,就是说要提交页面数据,比如新增和修改数据页面
2.Ext.Ajax.request常用在根据参数提交的时候,比如删除,我们把页面选中的ID进行遍历,封装在一个Array中,作为一个参数做Ajax的提交
例子:
首先是form1.getForm().submit的例子:
function formSubmit(){
if (form1.getForm().isValid()) {
form1.getForm().submit({
waitTitle : '提示',//标题
waitMsg : '正在提交数据请稍后...',//提示信息
url : 'eidtBooktype.action',
method : 'post',
params : 'booktype',
success : function(form, action) {
var flag=action.result.msg;
window.returnValue='SUCC';
Ext.Msg.alert('提示',flag,function(){
window.close();
});
},
failure : function(form,action) {
var flag=action.result.msg;
Ext.Msg.alert('操作', flag);
}
});
}
}
其次是一个Ext.Ajax.request的例子:
Ext.Ajax.request({
url : 'deleteBooktypes.action',
method : 'post',
params : {delids:deleteids.toString()},
success : function(form,action) {
//alert(response.responseText); //返回的json值的字符串
var respText = Ext.util.JSON.decode(form.responseText); //吧字符串变为json格式
var msg=respText.msg;
Ext.MessageBox.alert('提示',msg,function(){
bookTypeStore.reload();
});
},
failure : function(response,options) {
var respText = Ext.util.JSON.decode(response.responseText); //吧字符串变为json格式
var msg=respText.msg;
Ext.MessageBox.alert('提示',msg,function(){
bookTypeStore.reload();
});
}
});
使用是的区别:
最明显就是success和failure时候function的参数!
Ext.Ajax.request的function(response,options),option非常有用,用response.responseText获得返回参数,注意这个地方的response参数可以换成action
form1.getForm().submit的function(form, action),action很有用,用action.result.msg获得返回值
还有个最明显区别是Ext.Ajax.request不可以用waitMsg,真是Ext的一个败笔呀!!!
==============================================================================================
前置:
后台成功返回字符串:{success:true,msg:'操作成功!'}
后台失败返回字符串:{success:false,errors:'操作失败!'}
当submi提交时,action不存在后台返回下图字符串:
下面所有的action不存在,是指url路径不存在
FormPanel 提交代码如下:
-
var G = new Ext.form.FormPanel({})
-
-
G.getForm().submit({
-
url:wayfoon.MMS.DataPage +'/ext2Upload.action',
-
-
failure:function(form, action){
-
Ext.MessageBox.alert('警告', action.result.errors);
-
},
-
success: function(form, action){
-
Ext.MessageBox.alert('信息', action.result.msg);
-
}
-
});
var G = new Ext.form.FormPanel({}) G.getForm().submit({//客户端的数据提交给服务器 url:wayfoon.MMS.DataPage +'/ext2Upload.action', //waitMsg:"正在提交表单数据,请稍候。。。。。。", failure:function(form, action){ Ext.MessageBox.alert('警告', action.result.errors); }, success: function(form, action){ Ext.MessageBox.alert('信息' action.result.msg);
}
根据后台json 字符串 success的值(ture/false)自动选择failure或者success,也可以捕捉前台错误(走failure流程),比如数据非法而被强制提交时,
后台字符串需要通过action.result 转成json 字符串,供我们按习惯的方法使用,
对于后台异常处理,比如 action不存在,则无能为力,会出JavaScript错误,
错误处,ext-all.js的代码
-
this.decode = function(json) {
-
-
return eval("(" + json + ")")
-
}
this.decode = function(json) { //alert(json); return eval("(" + json + ")") }
原因是无法将上图(如图)的字符串转成json字符串,导致无法判断走哪个流程,而正常情况下,返回的是 {success:true,msg:'操作成功!'}或其他。
试了将上面代码使用try{}catch (){} 还是不能解决JavaScript错误,我们一般可以避免这种后台错误,如果非得解决的话,不知道有没有好的解决方法。
Ext.Ajax.request提交代码如下:
-
Ext.Ajax.request({
-
url:wayfoon.MMS.DataPage+'/cpSMS.action?action=submitSMS',
-
method:'POST',
-
params:'id='+id,
-
success:function(form,action){
-
var obj = Ext.util.JSON.decode(form.responseText);
-
if(obj.success==true)
-
{
-
Ext.Msg.alert('提示',obj.msg);
-
ds.reload();
-
}
-
else
-
{
-
-
Ext.Msg.alert('提示',obj.msg);
-
}
-
},
-
failure:function(form,action){
-
Ext.Msg.alert('警告','系统错误');
-
}
-
});
Ext.Ajax.request({ url:wayfoon.MMS.DataPage+'/cpSMS.action?action=submitSMS', method:'POST', params:'id='+id, success:function(form,action){ var obj = Ext.util.JSON.decode(form.responseText); if(obj.success==true) { Ext.Msg.alert('提示',obj.msg); ds.reload(); } else { //Ext.Msg.alert('提示',obj.errors); Ext.Msg.alert('提示',obj.msg); } }, failure:function(form,action){ Ext.Msg.alert('警告','系统错误'); } });
后台字符串通过Ext.util.JSON.decode 转成json字符串
不能自动根据json字符串success的值来选择流程 ,需要根据obj.success的值来判断走哪个流程
该failure:可以捕捉系统异常,比如,数据未曾提交到后台或action 不存在,此时走failure 流程
在 form中增加
errorReader : new Ext.data.XmlReader({
record : 'field',
success : '@success'
}, ['id', 'msg']),
属性的设置,可以 屏蔽 return eval("(" + json + ")") 引起的错误,因为源码中不会走Ext.decode这个流程,源码如下:
handleResponse : function(response){
if(this.form.errorReader){
var rs = this.form.errorReader.read(response);
var errors = [];
if(rs.records){
for(var i = 0, len = rs.records.length; i < len; i++) {
var r = rs.records;
errors = r.data;
}
}
if(errors.length < 1){
errors = null;
}
return {
success : rs.success,
errors : errors
};
}
return Ext.decode(response.responseText);
}
转载:http://blog.csdn.net/zzxll5566/article/details/6176693
相关推荐
主要介绍了ExtJs的Ext.Ajax.request实现waitMsg等待提示效果,需要的朋友可以参考下
extjs多选下拉框,Ext.ux.form.LovCombo,extjs 以修复多选下拉框火狐下取不到值的问题,火狐下div不显示背景色的问题
NULL 博文链接:https://maoyi606.iteye.com/blog/1782825
NULL 博文链接:https://sonckchi.iteye.com/blog/1958861
关于这个原因有很多种,我只说下我遇到的 我这样 写Store来复用的 代码如下: DocStore = Ext.extend(Ext.data.Store,{ initComponent:function(){ this.proxy = new Ext.data.HttpProxy({url:this.url}); this....
Ext Extjs 禁止文本和日期编辑 ExtJS中动态设置TextField的readOnly属性
1、Ext.ux.aceeditor.Panel 2、Ext.ux.grid.feature.Tileview 3、Ext.ux.upload.Button 4、Ext.ux.toggleslide.ToggleSlide 5、Ext.ux.container.ButtonSegment 6、Ext.ux.grid.plugin.RowEditing 7、Ext.ux.grid....
EXTjs的上传组件
ExtJS tooltip功能组件实例
《精通JS脚本之ExtJS框架》由浅入深地讲解了ExtJS在Web开发中的相关技术。本书共分17章,分别介绍了JavaScript的对象编程、JavaScript浏览器对象模型和事件机制、ExtJS的核心类库和组件、ExtJS的事件处理方式、设计...
extjs 可编辑的表格树,每个单元格自定义编辑组件,可以自适应列宽,只有源码与例子,运行实例要修改路径,不然图片不能显示,注意etree.jsp的js引入路径 支持Ext2.x以上版本 如运行不了EmailTo : codeme9@gmail....
《精通JS脚本之ExtJS框架》由浅入深地讲解了ExtJS在Web开发中的相关技术。本书共分17章,分别介绍了JavaScript的对象编程、JavaScript浏览器对象模型和事件机制、ExtJS的核心类库和组件、ExtJS的事件处理方式、设计...
Ext.ux.GoogleChart extjs插件Ext.ux.GoogleChart extjs插件
主要用例子说明extjs4的form表单的运用,其中有表单属性说明,表单控件运用说明如: title:'表单', //表单标题 bodyStyle:'padding:5 5 5 5', //表单边距 height:120, //表单高度 width:200, //表单宽度 ...
该ext.jsb2文件是ExtJS3.4.0中的,因ExtJS4.0.0中没有这个文件,但可以与4.0.0版本共用。
代码如下: Ext.onReady(function() { Ext.Msg.alert(‘提示’, ‘逗号分隔参数列表’); //这种方式非常常见的 }); 效果图: 代码如下: Ext.onReady(function() { //定义 JSON(配置对象) var config = { ...
EXTJS4.0 视频配套代码 EXT4 EXTJS4
ext.jsb spket ExtJS dreamweaver
NULL 博文链接:https://atian25.iteye.com/blog/1019910