2008-07-05
ruby+flex实现天气预报
研究一段时间flex后发现,actionscript3和ruby一样具有很强的动态性,可以构建十分强大的客户端,但目前对于一些主要基于文本的系统来说有点杀鸡用牛刀的感觉,可是未来的客户端正在朝着多媒体化的方向发展,因为这样会带来更高的用户体验。感觉flex在客户端上有着很好的表现,而ruby在后台业务处理上非常的灵巧,随着两者不断的成熟与发展,有理由相信两者的结合一定会在企业级AIR应用上开辟一片新天地。
下面是一个flex结合ruby on rails订阅天气预报的例子,实现起来比较简洁自然。
ruby端:
class WeathersController < ApplicationController
require 'rss/1.0'
require 'rss/2.0'
require 'open-uri'
def show
feed= "http://www.raychou.com/weather/rss.php?id=#{params[:code]}"
content = ""
open(feed) do |s|
content = s.read
end
@rss = RSS::Parser.parse(content, false)
render :xml => @rss.channel #无需解析直接发送
end
end
flex端:
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" width="624" height="426">
<mx:Script>
<![CDATA[
import mx.events.CloseEvent;
import mx.rpc.events.ResultEvent;
[Bindable]
private var cityName: Array = [ {label:"北京", data:"54511"},
{label:"南京", data:"58238"},
{label:"上海", data:"58367"}
];
[Bindable]
private var selectedItem:Object;
//处理请求,无需解析结果数据,直接用就可以了
private function resultWeather(event:ResultEvent):void{
item1.text = event.result.channel.item[0].title.toString();
item2.text = event.result.channel.item[1].title.toString();
item3.text = event.result.channel.item[2].title.toString();
}
]]>
</mx:Script>
<!--向后台发送http请求-->
<mx:HTTPService result="resultWeather(event);" id="getWeather" url="http://localhost:3000/weathers/show" useProxy="false">
<mx:request>
<code>{selectedItem.data}</code>
</mx:request>
</mx:HTTPService>
<mx:Panel x="171" y="54" width="418" height="333" layout="absolute" title="天气预报查询" fontWeight="bold" fontSize="13">
<mx:ComboBox x="120" y="28" id="cmbCityName" dataProvider="{cityName}" close="selectedItem=ComboBox(event.target).selectedItem;
getWeather.send();" width="164" fontSize="12"/>
<mx:Label x="10" y="81" id="item1" text="" width="367" fontSize="14" color="#0A6464"/>
<mx:Label x="10" y="126" id="item2" text="" width="367" fontSize="14" color="#0A6464"/>
<mx:Label x="10" y="171" id="item3" width="367" fontSize="14" color="#0A6464"/>
<mx:Label x="37" y="30" text="请选者城市"/>
</mx:Panel>
</mx:Application>
运行结果:

- 17:56
- 浏览 (184)
- 论坛浏览 (1010)
- 评论 (2)
- 分类: flex
- 相关推荐
- 浏览: 22500 次
- 性别:

- 来自: 天之涯

- 详细资料
搜索本博客
我的相册
A569194995207YAN
共 16 张
共 16 张
链接
最新评论
-
Rails简洁的模板系统Mall ...
刑天战士 写道liuqiang 写道你们这种做法是合理的,一般美工给出个大致的页 ...
-- by lix23 -
如何进行项目跟踪
1、项目一定要进行生命周期的选型,确定各个里程碑的时间段。2、用代码行或者经验值 ...
-- by y31307 -
对WebGame行业的一点看法
本来就是对校内反感,感觉里面没什么东西,还大张旗鼓的! 钱几天被女朋友啦上去帮她 ...
-- by 稻香麦甜 -
对WebGame行业的一点看法
确实,本来一直认为校内没什么戏,如果有有这些游戏的存在,那么这个网站就不再空洞了 ...
-- by 稻香麦甜 -
互联网创业与软件开发
对的,感觉创业之初,技术绝对是奠基石,然后才是市场推广之类的,个人觉得专业化倾向 ...
-- by JimyChen






评论排行榜