ext struts spring action ajax load failure 10

我的项目中使用extstruts2spring界面上表单填充如果用ajax的requst,可以进入success函数,并且能够取值,设置成功。Ext.Ajax.reque... 我的项目中使用ext struts2 spring
界面上表单填充如果用ajax的requst ,可以进入success函数,并且能够取值,设置成功。
Ext.Ajax.request( {url : url,……
如果表单填充使用表单自带的load,则每次都进入failure,而是failure中,却能够取到action从服务端拿到的响应。
form.load({ url:this.url,……
执行的时候,进入failure,将失败函数中的action中的result打印出来,可以看到就是我的action返回的数据

很纠结~~ 到底是什么问题啊,为什么每次都进failure~!~!
展开
 我来答
骄闽雪3630
2011-01-04 · TA获得超过3427个赞
知道小有建树答主
回答量:2833
采纳率:0%
帮助的人:1411万
展开全部
/*
* Ext JS Library 2.0 RC 1
* zrmcsd@gmail.com
*
*/

Ext.onReady(function(){
Ext.QuickTips.init();

function formatDate(value){
return value ? value.dateFormat('M d, Y') : '';
};
var fm = Ext.form;

var checkColumn = new Ext.grid.CheckColumn({
header: "有效",
dataIndex: 'indoor',
width: 55
});

var cm = new Ext.grid.ColumnModel([{
id:'doc_code',
header: "文档编号",
dataIndex: 'doc_code',
width: 220,
hidden: true, // 隐藏列
editor: new fm.TextField({
allowBlank: false
})
},{
id:'name',
header: "名称",
dataIndex: 'name',
width: 200,
editor: new fm.TextField({
allowBlank: false
})
},{
header: "说明",
dataIndex: 'label',
width: 150,
editor: new fm.TextField({
allowBlank: false
})
},{
header: "菜单",
dataIndex: 'price',
width: 120,
editor: new fm.TextField({
allowBlank: false
})
},{
header: "有效",
dataIndex: 'youx',
width: 120,
editor: new fm.TextField({
allowBlank: false
})
}
]);

// sortable
cm.defaultSortable = true;

var Plant = Ext.data.Record.create([
,
,
,
,
,

]);

// create the Data Store
var store = new Ext.data.Store({
// 载入自动生成的XML文件 xml文件格式 uft-8
url: 'moudlexml.jsp',

reader: new Ext.data.XmlReader({
record: 'plant'
}, Plant),

sortInfo:
});

// create the editor grid
var grid = new Ext.grid.EditorGridPanel({
store: store,
cm: cm,
renderTo: 'editor-grid',
width:600,
height:300,
autoExpandColumn:'name',
title:'模块管理',
frame:true,
plugins:checkColumn,
//clicksToEdit:10,//设置点击几次才可编辑
selModel: new Ext.grid.RowSelectionModel(),//设置单行选中模式, 否则将无法删除数据
tbar: [{
tooltip:'Add Plant',
iconCls:'add',
text: '添加行',
handler : function(){
var p = new Plant({
doc_code: '0',
name: '',
label:'',
price:'',
youx:'',
indoor: false
});
var n = grid.getStore().getCount();// 获得总行数
grid.stopEditing();
store.insert(n, p);
grid.startEditing(n, 0);
}
}, '-', {
text:'删除行',
tooltip:'remove ',
iconCls:'remove',
handler : function(){

var rs1 = grid.getSelectionModel().getSelected();// 返回值为 Record 类型
grid.stopEditing();
if(rs1==undefined)
{
return;//判断记录集是否为空,为空返回
}

Ext.MessageBox.confirm('确认删除', '你真的要删除所有用户信息吗?',
function(btn) {
if(btn == 'yes')
{
// var rs1 = store.getAt(1);
store.remove(rs1);

grid.startEditing(0, 0);
Ext.Msg.alert('友情提示','删除成功,很好很强大');
}
else
{
//Ext.Msg.alert('您成功修改了用户信息', "被修改 "+rs1.get("name") );// 取得用户名
Ext.Msg.alert('友情提示','很天真,怎么不删');
}
});

}

},'-',{
text:'保存',
tooltip:'Save item',
iconCls:'option'
}]
});

// 单元格编辑后事件处理,暂不用
grid.on("afteredit", afterEdit, grid);

function afterEdit(e) {// 事件处理函数
var record = e.record;// 被编辑的记录
Ext.Msg.wait("请等候", "修改中", "操作进行中..."); // 显示等待对话框
// 更新界面, 来真正删除数据
Ext.Msg.alert('您成功修改了用户信息', "被修改的用户是:" + e.record.get(e.field) + "\n 修改的字段是:" + e.field);
};

//*****************************编辑窗口*****************************************************************
var simple = new Ext.FormPanel({
renderTo:'form-grid',//inner到哪个容器中
labelWidth: 75, // label settings here cascade unless overridden
url:'baododododododododo',
frame:true,
title: '编辑器',
bodyStyle:'padding:5px 5px 0',
width: 350,
defaults: ,
defaultType: 'textfield',

items: [{
fieldLabel: '名称',
name: 'name_e',
allowBlank:false
},{
fieldLabel: '菜单',
name: 'label_e',
allowBlank:false
},{
fieldLabel: '说明',
name: 'price_e',
allowBlank:false

}, {
fieldLabel: '是否有效',
name: 'youx_e'
}
],

buttons: [{
text: '保存',
handler : function(){

Ext.Ajax.request({
url : 'addrow.jsp' ,
params :'action=edit&name='+Ext.getDom('name_e').value,
method: 'GET',
text: "Updating...",
success: function ( result, request )
{
var rs1 = grid.getSelectionModel().getSelected();// 返回值为 Record 类型
var p = new Plant({
doc_code: '0',
name: Ext.getDom('name_e').value,
label:Ext.getDom('label_e').value,
price:Ext.getDom('price_e').value,
youx:Ext.getDom('youx_e').value ,
indoor: false
});
var n = store.indexOf(rs1);// 获得点击行的index

//本来想用替换方法 试了几次不爽 还是自己的增删吧
store.insert( n , p);
store.remove(rs1);
Ext.MessageBox.alert('访问成功', '数据返回的数据 '+ result.responseText);

},
failure: function ( result, request)
{
Ext.MessageBox.alert('访问失败', '失败了就没好说的了 (*^__^*) 嘻嘻……: ');
}
});

}
},{
text: '取消'
}]
});

// 载入数据
store.load();

// 单元格单击后事件处理
grid.on("click", clickedit, grid);

function clickedit(e) {

var rs1 = grid.getSelectionModel().getSelected();// 返回当前行的记录集
//getDom 获取Dom元素的方法
Ext.getDom('name_e').value=rs1.get('name'); //
Ext.getDom('label_e').value=rs1.get('label'); //
Ext.getDom('price_e').value=rs1.get('price'); //说
Ext.getDom('youx_e').value=rs1.get('youx'); //是否有效

};

});
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式