当前位置: 首页 > 图文教程 > Flash动画 > ActionScript > FLASH AS3与网页JS参数值传递的问题

ActionScript
ActionScript3教程:语句实例
ActionScipt技巧和开发中会遇到的问题
Flash as3.0教程:弹性小球
flash as简单制作飘雪动画
Flash AS 教程:交互动画
Flash ActionScript 3.0教程:学习Dot类
Flash AS 教程:子类化显示对象
Flash AS 教程:动画事件
Flash AS 教程:创建文档类(Document class)
Flash AS 教程:帧循环
Flash AS 教程:类和面向对象编程
Flash AS 教程:构造函数(Constructor)
Flex程序开发心得小结
Flash游戏开发教程:第一节
FLASH中的元件能在Flex中完美使用
关于XML在FLASH中的应用
Flash AS教程:decorator Pattern
Flash AS实例教程:简单的loading
Flash教程:彻底学习RadioButton组件
Flash AS教程:复制粘贴类

ActionScript 中的 FLASH AS3与网页JS参数值传递的问题


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-16   浏览: 60 ::
收藏到网摘: n/a

让我们一干人等郁闷了1个多小时的一个问题,结果才发现,JS处理JSON结构的时候,如果JSON格式与所需的不符,则函数都不会执行。

问题起因:AS3调用PHP,PHP异步返回一个XML结构,AS3取XML结构中的某些节点值赋给某个对象,然后通过与JS交互将值传递给JS。

调试过程:
PS item为PHP返回的xml:
varobj_info:Object=newObject();
obj_info["from"]=item..from;
obj_info["context"]=item..text;

trace("UserMessage-->Messagefromservicechat::" obj_info);
trace("UserMessage-->Messagefromservicechatfrom::" obj_info["from"]);
trace("UserMessage-->Messagefromservicechatcontext::" obj_info["context"]);
this.dispatchEvent(newMessageEvent(MessageEvent.USERGETSUCCESS,obj_info)); 此处输出:
UserMessage-->Messagefromservicechat::[objectObject]
UserMessage-->Messagefromservicechatfrom::[objectObject]
UserMessage-->Messagefromservicechatcontext::[objectObject] 这个obj_info对象就是传递给JS的对象,而JS需要的JSON结构为: { "from" : "...", "context" : "..." } ,这两个属性值都为string类型。

发现错误点:JS内部调用函数时,在三种情况下调试:1、不传参数给函数;2、传一个正确类型和结构的JSON作为参数;3、传一个不正确类型和结构的JSON作为参数。 经过这三次调试后发现,如果JSON结构不正确,则JS函数不会执行。 这样一来,问题就转到了Flash传递给JS的参数上。对比之前Flash的调试输出的结果,确认Flash从PHP获取到XML后,在给传递给JS参数赋值的时候需要强制转换。

最后解决方法:修改赋值部分代码:
varobj_info:Object=newObject();
obj_info["from"]=(item..from).toString();
obj_info["context"]=(item..text).toString();

trace("UserMessage-->Messagefromservicechat::" obj_info);
trace("UserMessage-->Messagefromservicechatfrom::" obj_info["from"]);
trace("UserMessage-->Messagefromservicechatcontext::" obj_info["context"]);
this.dispatchEvent(newMessageEvent(MessageEvent.USERGETSUCCESS,obj_info));