Extjs分页时遇上ivalid label的解决原理

这一周在学extjs,1然后在使用ExtjsPagingGrid分页时,总是碰到ivalid label 这个错误,也在网上看了一些资料,可是多数都没有提到如何解决ivalid label,有部份提到解决方法(将json-data前后加上括号然后再返回等),可是实验过后是错误的,经过问题重现,发现:

1同一个文件在用Ext.data.httpProxy访问时能正常显示

2在用Ext.data.ScriptTagProxy的时候才出现上述错误(因为想实现跨域访问后台分页的文件,所以必须用这个,要不然也不会发现用ScriptTagProxyhttpProxy访问一个一样的文件时结果会不正确)

然后我就再次查看ext 2.1的范例,仍然没有发现什么,因为范例中的后台分页文件所返回的数据格式与我的一样,令我再次迷茫……(看不懂php文件,也许看得懂的话能够查出问题所在)

我相信,我肯定有些地方漏掉了……然后我便以重新学习extjs的心态对着Ext.data.ScriptTagProxy这部份文档再次慢慢的阅读.发现有这么一段:

In order for the browser to process the returned data, the server must wrap the data object with a call to a callback function, the name of which is passed as a parameter by the ScriptTagProxy.…………

我想我应该找到问题的关健了……

其实原因很简单就是使用ScriptTagProxy时要从request参数中获得callback属性,把得到的参数跟json-data一起返回,因为返回的data是要在浏览器中执行的所以仅仅返回json-data是不够的,需要构造成callBackName(json-data)这种形式返回。

JAVA 代码如下:

String cb = request.getParameter("callback");//获得callback属性

response.getWriter()write(cb + “(”+ json-data + ");");//json-data进行重新包装

 

C#代码如下:

string cb = Request.Params.Get(3).ToString();//获得callback属性

Response.Write(cb + "(" + json-data + ");");//json-data进行重新包装

 

Note:关于response.contentType也需要依据是否有callback进行设置,如果未设的情况下用application/x-json,存在callback属性时用text/javascript.


转载于:https://www.cnblogs.com/zhongru_tu/archive/2008/06/27/1231184.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值