`
liuqiang
  • 浏览: 162559 次
  • 性别: Icon_minigender_1
  • 来自: 华东
社区版块
存档分类
最新评论

ruby+flex实现天气预报

    博客分类:
  • iOS
阅读更多

      研究一段时间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>

 

运行结果:

分享到:
评论
8 楼 chen_miao 2012-10-08  
我是初学者,请问,我在flex设计好了带有按钮和下拉框的界面,怎么结合到ruby 中呢,一般方法有哪些啊
7 楼 天机老人 2009-02-20  
呵呵,现在flex与ruby互相通信的方式有几种?
和java一样多么?
还是比较讨厌写过的类要在flex里再写一遍……
6 楼 seemoon 2009-02-19  
第一次看flex的脚本,看来是一整个xml啊。
5 楼 yerba 2009-02-18  
貌似用绑定的方式更加简单,代码也更少。
4 楼 czwlucky 2009-02-18  
发现一个比较奇怪的现象,google reader上看到的有一条1970年1月1日的信息,不知道这又是什么原因?楼主设置了什么呢,还是访问方的原因呢?
3 楼 czwlucky 2009-02-18  
<pre name="code" class="xml">&lt;?xml version="1.0" encoding="utf-8"?&gt;
&lt;mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" applicationComplete="http.send();"&gt;
&lt;mx:HTTPService id="http" method="GET" url="http://rss.news.sohu.com/rss/guonei.xml" resultFormat="object" useProxy="false" fault="mx.controls.Alert.show(event.fault.faultString);"&gt;
&lt;/mx:HTTPService&gt;
&lt;mx:Panel left="10" top="10" right="10" bottom="10" layout="absolute" title="BlogReader({http.lastResult.rss.channel.title})" fontSize="14"&gt;
&lt;mx:DataGrid id="doPost" left="20" right="20" top="20" bottom="343" dataProvider="{http.lastResult.rss.channel.item}" change="btn.visible=true" fontSize="14"&gt;
&lt;mx:columns&gt;
&lt;mx:DataGridColumn headerText="标题" dataField="title" showDataTips="true"/&gt;
&lt;mx:DataGridColumn headerText="日期" dataField="pubDate"/&gt;
&lt;/mx:columns&gt;
&lt;/mx:DataGrid&gt;
&lt;mx:TextArea left="20" right="20" height="300" bottom="46" text="{doPost.selectedItem.description}" fontSize="14"/&gt;
&lt;mx:LinkButton id="btn" right="20" bottom="20" label="详细内容" visible="false" width="109" click="navigateToURL(new URLRequest(doPost.selectedItem.link));"/&gt;
&lt;/mx:Panel&gt;
&lt;/mx:Application&gt;</pre>
<p> 上面的代码不论是在什么情况下都可以正常显示的,可我迷惑的是下面的代码只是改成你的天气预报地址却不行了,在我的桌面上报“安全沙箱”异常,请问这是什么原因呢?为什么上面的没有安全问题呢?</p>
<pre name="code" class="xml">&lt;?xml version="1.0" encoding="utf-8"?&gt;
&lt;mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" applicationComplete="http.send();"&gt;
&lt;mx:HTTPService id="http" method="GET" url="http://weather.raychou.com/?/detail/54511/rss" resultFormat="object" useProxy="false" fault="mx.controls.Alert.show(event.fault.faultString);"&gt;
&lt;/mx:HTTPService&gt;
&lt;mx:Panel left="10" top="10" right="10" bottom="10" layout="absolute" title="BlogReader({http.lastResult.rss.channel.title})" fontSize="14"&gt;
&lt;mx:DataGrid id="doPost" left="20" right="20" top="20" bottom="343" dataProvider="{http.lastResult.rss.channel.item}" change="btn.visible=true" fontSize="14"&gt;
&lt;mx:columns&gt;
&lt;mx:DataGridColumn headerText="标题" dataField="title" showDataTips="true"/&gt;
&lt;mx:DataGridColumn headerText="日期" dataField="pubDate"/&gt;
&lt;/mx:columns&gt;
&lt;/mx:DataGrid&gt;
&lt;mx:TextArea left="20" right="20" height="300" bottom="46" text="{http.lastResult.html.body}" fontSize="14"/&gt;
&lt;mx:LinkButton id="btn" right="20" bottom="20" label="详细内容" visible="false" width="109" click="navigateToURL(new URLRequest(doPost.selectedItem.link));"/&gt;
&lt;/mx:Panel&gt;
&lt;/mx:Application&gt;</pre>
<p>    所以测试这个,是因为我在我的服务器上写的xml也出现同样问题,不能在桌面上访问。知道原因的大侠们请多多赐教呀。。。</p>
<p>   先谢谢各位了!</p>
2 楼 vicker 2008-08-28  
很想了解多一点这方面的内容,不过感觉学习的资料很少。
1 楼 0701 2008-08-07  
flex和rails结合可以考虑使用AMF,不知道是WebORB好还是RubyAMF好用,据说WebORB的bug要少一点

相关推荐

    RUBY+1.8 windows UI

    标题“RUBY+1.8 windows UI”指的是针对Windows平台的Ruby 1.8版本的用户界面安装程序,它为用户提供了简便的方式来安装和配置Ruby运行环境。 Ruby 1.8是Ruby的一个较早版本,发布于2003年,包含了众多核心库和API...

    开放Ruby+watir 自动化测试工具介绍+安装说明

    Ruby和Watir(Web Application Testing in Ruby)是一个强大的自动化测试框架,主要用于Web应用程序的测试。Ruby是一种面向对象的、动态的编程语言,以其简洁、优雅的语法和强大的元编程能力而受到开发者的喜爱。...

    ruby+watir自动论坛发帖

    ruby+watir技术实现的论坛发帖机器人,不完善。

    ruby+selenium-webdriver测试--第一个例子源代码

    在这个“ruby+selenium-webdriver测试--第一个例子源代码”中,我们将探讨如何使用Ruby和Selenium-Webdriver实现自动化测试的初步步骤。 首先,我们需要安装必要的库。确保已经安装了Ruby,并通过RubyGems来安装...

    基于Ruby+Java搜索引擎原理与实现

    《基于Ruby+Java搜索引擎原理与实现》是一部深入探讨搜索引擎技术的书籍,虽然只涵盖了前三个章节,但已足以让我们对搜索引擎的基本运作有初步的理解。在本文中,我们将围绕Ruby和Java这两种编程语言如何应用于搜索...

    ruby安装包-rubyinstaller-devkit-3.0.2-1-x64.zip

    Ruby是一种面向对象、动态类型的脚本语言,由Yukihiro "Matz" Matsumoto于1995年创建。它以其简洁、优雅的语法和强大的编程能力而闻名,广泛应用于Web开发、脚本自动化、服务器管理等领域。RubyInstaller是Windows...

    Ruby+Rails+社交+教程

    这个“Ruby+Rails+社交+教程”显然旨在引导开发者如何利用Rails的灵活性和强大功能构建一个完整的社交平台。以下是教程可能涵盖的一些核心知识点: 1. **Ruby基础知识**:首先,你需要对Ruby编程语言有基本的理解,...

    Ruby+Rails+社交+进阶教程5

    在本“Ruby+Rails+社交+进阶教程5”中,我们将深入探讨如何利用Ruby on Rails框架构建一个功能丰富的社交网络平台。Ruby on Rails(简称Rails)是一个基于Ruby语言的开源Web应用程序框架,它遵循MVC(模型-视图-控制...

    Ruby+for+Rails

    **Ruby for Rails** Ruby是一种面向对象的动态编程语言,它以其简洁、优雅的语法和强大的元编程能力而闻名。在Web开发领域,Ruby与Rails框架的结合,即Ruby on Rails(RoR),开创了Web应用的新纪元。Ruby on Rails...

    ruby+ruvygems+redis.gem.rar

    标题 "ruby+ruvygems+redis.gem.rar" 涉及到的是一份压缩包,其中包含了构建和操作Redis集群环境所需的Ruby编程语言、RubyGems包管理和Redis数据库的相关组件。以下是关于这三个核心概念的详细说明: 1. **Ruby**:...

    ruby(前途大好的ruby+rains)

    5. **闭包**:Ruby中的 Proc 和 lambda 实现了闭包,能够捕获其定义时的上下文环境,这在函数式编程中非常有用。 6. **模块(Module)**:Ruby的模块用于实现命名空间,代码重用和混合(mixin)功能。一个类可以...

    Ruby+Rails+社交+教程3

    本教程“Ruby+Rails+社交+教程3”旨在帮助开发者掌握如何利用Ruby的强大功能和Rails的优雅设计来构建一个具有用户交互性的社交平台。 首先,让我们深入了解一下Ruby。Ruby是一种面向对象的编程语言,以其简洁、易读...

    ruby+watir 测试框架

    在Ruby+Watir测试框架中,我们可以通过编写Ruby脚本来模拟用户在Web应用中的行为,如点击按钮、填写表单、验证页面内容等。Watir支持多种浏览器,包括Chrome、Firefox、Safari等,为测试提供了跨平台的兼容性。 ...

    rubyonrails+Ruby+取得指定月日期数方法

    Ruby on Rails 是一个使用 Ruby 语言编写的开源 web 应用框架,它遵循 MVC(模型-视图-控制器)架构模式。Ruby 是一种高级、解释型、面向对象的脚本语言,其设计哲学强调代码的可读性和简洁的语法。在 Ruby on Rails...

    ruby + watri 自动化部署集成Eclipse 全量安装包

    ruby + watri 自动化部署集成Eclipse 全量安装包 (包括:watir-1.5.4、ruby186-26、WatirRecorder_Setup_lite、dltk-core-ruby、dotnetfx、rubygems-1.3.7、安装说明)

    ruby+voodoo

    在这个场景中,“ruby+voodoo”可能是指一个使用Ruby语言实现的名为“Voodoo”的框架或库。 Ruby语言的核心特点包括: 1. 面向对象:Ruby是完全面向对象的语言,每一个数据类型都是对象,甚至基本类型如整数、字符...

    ruby+selenium-webdriver测试源代码003

    在本资源中,我们关注的是使用Ruby和Selenium-Webdriver进行自动化测试的源代码,具体为"test003"。Ruby是一种流行的、动态的、面向对象的编程语言,而Selenium-Webdriver则是一个强大的工具,允许我们对浏览器进行...

Global site tag (gtag.js) - Google Analytics