c# AJAX实践VS2005 + RSSToolKit  开发你自己的RSS在线阅读器

Rss 是一种描述和同步网站内容的格式,是目前使用最广泛的XML应用。RSS 搭建了信息迅速传播的一个技术平台,使得每个人都成为潜在的信息提供者。发布一个 Rss 文件后,这个 Rss  Feed中包含的信息就能直接被其他站点调用,而且由于这些数据都是标准的XML格式,所以也能在其他的终端和服务中使用。

在之前我们如果要实现博客的RSS订阅,通常都需要手写代码去生产或读取XML。现在有了RSSToolKit,这一切就变得简单了。你可以使用他在五分钟内实现自己的 Rss 在线阅读器。这篇文章将介绍如何读取站点 Rss 信息。

开发环境:VS2005 + RSSToolKit

一、首先我们需要建立一个ASP.NET AJAX站点

二、引入RssToolKit到项目中,建好的项目如下(CSS和图片文件可以使用我压缩文档里的)


三、可以开始写代码了
       1.首先需要一个ScriptManager、一个UpdatePanel、一个UpdateProgress。哈哈,都是废话AJAX页面程序大概都需要这些。其他的就是你的要求了。具体的页面代码如下:
  1 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>
  2 
  3 <%@ Register Assembly="RssToolkit" Namespace="RssToolkit" TagPrefix="Rss" %>
  4 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
  5 <html xmlns="http://www.w3.org/1999/xhtml">
  6 <head runat="server">
  7     <title>向东博客阅读器|meil.livebaby.cn</title>
  8     <link href="CSS/Layout.css" rel="stylesheet" type="text/css" />
  9 
 10     <script language="JavaScript" type="text/javascript">
 11     var ls;
 12     function ls_onClk(itemNumber) {
 13     
 14         if(ls == null) ls = $get("List0");
 15         
 16         ls.className = "";
 17         ls = $get("list" + itemNumber);
 18         ls.className = "current";
 19         return true;
 20     }
 21     </script>
 22 
 23 </head>
 24 <body>
 25     <form id="form1" runat="server">
 26         <asp:ScriptManager ID="ScriptManager1" runat="server" />
 27         <div id="content-header">
 28             <h1><asp:HyperLink ID="HyperLink1" runat="server" Text="向东" Target="_blank" NavigateUrl="http://meil.livebaby.cn/index.html"></asp:HyperLink>
 29                 博客阅读器</h1>
 30         </div>
 31         <div id="content-container">
 32             <div id="content-side1">
 33                 <ul class="list-of-links">
 34                    <li id="list0" class="current">
 35                         <asp:LinkButton ID="lb0" runat="server" CommandArgument="0" OnClientClick="ls_onClk(0);" OnCommand="lnk_cmd">向东博客</asp:LinkButton></li>
 36                    <li id="list1">
 37                         <asp:LinkButton ID="lb1" runat="server" CommandArgument="1" OnClientClick="ls_onClk(1);" OnCommand="lnk_cmd">财经博客</asp:LinkButton></li>
 38                     <li id="list2">
 39                         <asp:LinkButton ID="lb2" runat="server" CommandArgument="2" OnClientClick="ls_onClk(2);" OnCommand="lnk_cmd">Flower博客</asp:LinkButton></li>
 40                     <li id="list3">
 41                         <asp:LinkButton ID="lb3" runat="server" CommandArgument="3" OnClientClick="ls_onClk(3);" OnCommand="lnk_cmd">活力宝贝博客网</asp:LinkButton></li>
 42                     <li id="list4">
 43                         <asp:LinkButton ID="lb4" runat="server" CommandArgument="4" OnClientClick="ls_onClk(4);" OnCommand="lnk_cmd">悠悠宝贝的博客</asp:LinkButton></li>
 44                     <li id="list5">
 45                         <asp:LinkButton ID="lb5" runat="server" CommandArgument="5" OnClientClick="ls_onClk(5);" OnCommand="lnk_cmd"><font color="red">向东博客园博客</font></asp:LinkButton></li>
 46                     <li id="li6">
 47                         <asp:LinkButton ID="lb6" runat="server" CommandArgument="6" OnClientClick="ls_onClk(6);" OnCommand="lnk_cmd"><font color="red">博客园</font></asp:LinkButton></li>
 48                 </ul>
 49             </div>
 50             <div id="content-main">
 51                 <asp:UpdatePanel ID="updateMain" runat="server" UpdateMode="conditional" >
 52                     <Triggers>
 53                         <asp:AsyncPostBackTrigger ControlID="lb0" />
 54                         <asp:AsyncPostBackTrigger ControlID="lb1" />
 55                         <asp:AsyncPostBackTrigger ControlID="lb2" />
 56                         <asp:AsyncPostBackTrigger ControlID="lb3" />
 57                         <asp:AsyncPostBackTrigger ControlID="lb4" />
 58                         <asp:AsyncPostBackTrigger ControlID="lb5" />
 59                         <asp:AsyncPostBackTrigger ControlID="lb6" />
 60                     </Triggers>
 61                     <ContentTemplate>
 62                         <h2><asp:Label ID="lblHeader" runat="server">最新日志</asp:Label></h2>
 63                         <hr />
 64                         <asp:Panel ID="pnlBlog" runat="server">
 65                             <Rss:RssDataSource ID="rssDS" runat="server" MaxItems="0" Url=""></Rss:RssDataSource>
 66                             <asp:DataList ID="lsBlog" runat="server" DataSourceID="rssDS">
 67                                 <ItemTemplate>
 68                                     <asp:Panel ID="panelHeader" runat="server" Style="cursor: pointer; color: #d61719;width: 100%; display: block;">
 69                                         <span style="float: left;"><%# Eval("title") %></span>
 70                                         <asp:Image ID="Image1" runat="server" Style="float: right;" ImageUrl="~/images/expand_blue.jpg" />
 71                                     </asp:Panel>
 72                                     <asp:Panel ID="Panel1" runat="server" Style="margin-top: 3px;width: 100%; background: transparent url(images/blogBack.gif) no-repeat text-top left;">
 73                                         <%# Eval("description") %>
 74                                         (<asp:HyperLink ID="hlMore" runat="server" NavigateUrl='<%# Eval("link") %>' Target="_blank" Text="更多内容"></asp:HyperLink>)
 75                                     </asp:Panel>
 76                                     <ajaxT:CollapsiblePanelExtender ID="cpe1" runat="server" TargetControlID="Panel1"
 77                                         ExpandControlID="panelHeader" CollapseControlID="panelHeader" SuppressPostBack="true"
 78                                         ImageControlID="Image1" Collapsed="true" ExpandedImage="~/images/collapse_blue.jpg"
 79                                         CollapsedImage="~/images/expand_blue.jpg" />
 80                                     <hr style="border-bottom: 1px dotted #B2B2B2; margin: 0px;" />
 81                                 </ItemTemplate>
 82                             </asp:DataList>
 83                         </asp:Panel>
 84                     </ContentTemplate>
 85                 </asp:UpdatePanel>
 86             </div>
 87         </div>
 88         <asp:UpdateProgress ID="UpdateProgress1" runat="server" DisplayAfter="0" DynamicLayout="true">
 89             <ProgressTemplate>
 90                 <div id="updProgress">
 91                     <img alt="" src="images/indicator.gif" />
 92                     <span>数据获取中</span>
 93                 </div>
 94             </ProgressTemplate>
 95         </asp:UpdateProgress>
 96     </form>
 97     <center><div><a href="http://meil.livebaby.cn">meil.livebaby.cn</a>&nbsp;&nbsp;程序制作:向东&nbsp;&nbsp;2007.7</center>
 98 </body>
 99 </html>
100 
比较重要的是这两部分:
行66:<Rss:RssDataSource ID="rssDS" runat="server" MaxItems="0" Url=""></Rss:RssDataSource>
这就是实现RSS读取的核心了,有了这个标记就实现了RSS读取的一半工作,那剩下的吶?

看看下面者部分,lnk_cmd 命令实现了RSS数据的重绑定,这样你就可以实时的访问多个RSS地址了。如果你觉得这样还不够灵活,可以加个Textbox,然后用程序去绑定,这样也不错。不过,此次就不实现这个了,有兴趣的朋友可以试试,应该不难。哈哈!

代码如下:

行35:<asp:LinkButton ID="lb0" runat="server" CommandArgument="0" OnClientClick="ls_onClk(0);"  
                                      OnCommand="lnk_cmd">向东博客</asp:LinkButton></li> 
1     protected void lnk_cmd(object sender, CommandEventArgs e) 
2     { 
3         int command = Convert.ToInt32(e.CommandArgument); 
4  
5         rssDataBind(command); 
6     } 
rssDataBind就是绑定的函数,代码是: 
 1     protected void rssDataBind(int cmd) 
 2     { 
 3         switch (cmd) 
 4         { 
 5             case 0: 
 6                 rssDS.Url = "http://www.livebaby.cn/blog/u/meil/rss2.xml"; 
 7                 lsBlog.DataBind(); 
 8                 lblHeader.Text = "向东博客"; 
 9                 break; 
10             case 1: 
11                 rssDS.Url = "http://www.livebaby.cn/blog/u/money/rss2.xml"; 
12                 lsBlog.DataBind(); 
13                 lblHeader.Text = "财经博客"; 
14                 break; 
15             case 2: 
16                 rssDS.Url = "http://www.livebaby.cn/blog/u/flower/rss2.xml"; 
17                 lsBlog.DataBind(); 
18                 lblHeader.Text = "Flower博客"; 
19                 break; 
20             case 3: 
21                 rssDS.Url = "http://www.livebaby.cn/blog/rss2.asp"; 
22                 lsBlog.DataBind(); 
23                 lblHeader.Text = "活力宝贝博客网"; 
24                 break; 
25             case 4: 
26                 rssDS.Url = "http://www.livebaby.cn/blog/u/yoyo/rss2.xml"; 
27                 lsBlog.DataBind(); 
28                 lblHeader.Text = "悠悠宝贝的博客"; 
29                 break; 
30             case 5: 
31                 rssDS.Url = "http://www.cnblogs.com/meil/rss"; 
32                 lsBlog.DataBind(); 
33                 lblHeader.Text = "向东博客园博客"; 
34                 break; 
35             case 6: 
36                 rssDS.Url = "http://www.cnblogs.com/rss"; 
37                 lsBlog.DataBind(); 
38                 lblHeader.Text = "博客园"; 
39                 break; 
40             default: 
41                 break; 
42         } 
43     }

就这么简单
 rssDS.Url = "http://www.livebaby.cn/blog/u/meil/rss2.xml";
 lsBlog.DataBind();
是不是就如DB数据的绑定。MS的东西虽然结构性不好,但是上手真的好快。
到底需要多少个Case就看你的需要了。我这里就绑定了六个RSS地址,你还可以更多,但要注意的是一定要和页面上的LinkButton数对应上。

最终的C#代码如下:


代码如下:

1     protected void rssDataBind(int cmd) 
 2     { 
 3         switch (cmd) 
 4         { 
 5             case 0: 
 6                 rssDS.Url = "http://www.livebaby.cn/blog/u/meil/rss2.xml"; 
 7                 lsBlog.DataBind(); 
 8                 lblHeader.Text = "向东博客"; 
 9                 break; 
10             case 1: 
11                 rssDS.Url = "http://www.livebaby.cn/blog/u/money/rss2.xml"; 
12                 lsBlog.DataBind(); 
13                 lblHeader.Text = "财经博客"; 
14                 break; 
15             case 2: 
16                 rssDS.Url = "http://www.livebaby.cn/blog/u/flower/rss2.xml"; 
17                 lsBlog.DataBind(); 
18                 lblHeader.Text = "Flower博客"; 
19                 break; 
20             case 3: 
21                 rssDS.Url = "http://www.livebaby.cn/blog/rss2.asp"; 
22                 lsBlog.DataBind(); 
23                 lblHeader.Text = "活力宝贝博客网"; 
24                 break; 
25             case 4: 
26                 rssDS.Url = "http://www.livebaby.cn/blog/u/yoyo/rss2.xml"; 
27                 lsBlog.DataBind(); 
28                 lblHeader.Text = "悠悠宝贝的博客"; 
29                 break; 
30             case 5: 
31                 rssDS.Url = "http://www.cnblogs.com/meil/rss"; 
32                 lsBlog.DataBind(); 
33                 lblHeader.Text = "向东博客园博客"; 
34                 break; 
35             case 6: 
36                 rssDS.Url = "http://www.cnblogs.com/rss"; 
37                 lsBlog.DataBind(); 
38                 lblHeader.Text = "博客园"; 
39                 break; 
40             default: 
41                 break; 
42         } 
43     }

源码下载地址:http://www.cnblogs.com/Files/meil/ReaderRss_src.rar
本文永久地址: http://www.livebaby.cn/blog/u/meil/archives/2007/1169.html

(0)

相关推荐

  • 轻松学习jQuery插件EasyUI EasyUI创建RSS Feed阅读器

    本文实例讲述了通过 jQuery EasyUI框架创建一个RSS阅读器,分享给大家供大家参考.具体如下: 运行效果截图如下: 我们将使用以下插件: layout:创建应用的用户界面. datagrid:显示 RSS Feed 列表. tree:显示 feed 频道. 步骤 1:创建布局(Layout) <body class="easyui-layout"> <div region="north" border="false"

  • 基于JSP的RSS阅读器的设计与实现方法(推荐)

    阅读器访问地址:http://easyrss.tk/,欢迎体验! 阅读导览 一. 概述 二. 设计的基本概念和原理 三. 设计方案 四. 主要源代码 五. 阅读器使用说明 概述 获得信息是在人类的生活中是必不可少的环节.如果现在的社会对获得信息不快捷,那么这个社会将不会像如今这般的发达和进步.在当今网络技术相当发达的今天,大量的信息充斥在网上.现在网络越来越发达,用户在网上既能工作也能娱乐.当用户在网上需浏览很多个网站才能获取自己多需的信息时,那就感觉很累.因为现在每个网站都有很多信息,找到自己

  • 用Python的Django框架来制作一个RSS阅读器

    Django带来了一个高级的聚合生成框架,它使得创建RSS和Atom feeds变得非常容易. 什么是RSS? 什么是Atom? RSS和Atom都是基于XML的格式,你可以用它来提供有关你站点内容的自动更新的feed. 了解更多关于RSS的可以访问 http://www.whatisrss.com/, 更多Atom的信息可以访问 http://www.atomenabled.org/. 想创建一个联合供稿的源(syndication feed),所需要做的只是写一个简短的python类. 你可

  • 使用AngularJS制作一个简单的RSS阅读器的教程

    简介 几年前,我用C#写了一个RSS阅读器,但是我想如果把它做成一个SPA(单页应用)效果会更好. Angular使一些事情变得简单,RSS阅读器就是其中之一. 我也用Twitter Bootstrap(做UI)实现了RSS阅读器,调试页面样式是最难的地方之一...可能是因为我不擅长css的原因. 背景 我有一些自己喜欢的网站( CodeProject, Dr.Dobb's Journal, ComputerWorld, Inc. Magazine). 然而,我发现其中很多网站都有烦人的广告.风

  • Asp+Rss阅读器制作第1/2页

    Asp+Rss阅读器制作转自凌云的BLOG 我在这里只是作了一个测试.大家可以把它具体应用,调用自己站点中的最新帖,方便用户订阅. RSS阅读器显示页面代码如下:  复制代码 代码如下: <!--#include file="conn.asp"--> <% '****************************** '文件名:index.asp '功 能:RSS阅读器显示页面 '日 期:2006-6-19 '编 程:Cloud.L '***************

  • Python实现的RSS阅读器实例

    本文实例讲述了Python实现的RSS阅读器.分享给大家供大家参考.具体如下: # -*- coding:utf-8 -*- # file: pyRSS.py # import Tkinter import urllib import xml.parsers.expat class MyXML: # XML解析类 def __init__(self, edit): self.parser = xml.parsers.expat.ParserCreate() # 生成XMLParser self.

  • c# AJAX实践VS2005 + RSSToolKit 开发你自己的RSS在线阅读器

    Rss 是一种描述和同步网站内容的格式,是目前使用最广泛的XML应用.RSS 搭建了信息迅速传播的一个技术平台,使得每个人都成为潜在的信息提供者.发布一个 Rss 文件后,这个 Rss  Feed中包含的信息就能直接被其他站点调用,而且由于这些数据都是标准的XML格式,所以也能在其他的终端和服务中使用. 在之前我们如果要实现博客的RSS订阅,通常都需要手写代码去生产或读取XML.现在有了RSSToolKit,这一切就变得简单了.你可以使用他在五分钟内实现自己的 Rss 在线阅读器.这篇文章将介绍

  • c# AJAX实践VS2005 + RSSToolKit  开发你自己的RSS在线阅读器

    Rss 是一种描述和同步网站内容的格式,是目前使用最广泛的XML应用.RSS 搭建了信息迅速传播的一个技术平台,使得每个人都成为潜在的信息提供者.发布一个 Rss 文件后,这个 Rss  Feed中包含的信息就能直接被其他站点调用,而且由于这些数据都是标准的XML格式,所以也能在其他的终端和服务中使用. 在之前我们如果要实现博客的RSS订阅,通常都需要手写代码去生产或读取XML.现在有了RSSToolKit,这一切就变得简单了.你可以使用他在五分钟内实现自己的 Rss 在线阅读器.这篇文章将介绍

  • 同时安装vs2005团队开发版和sql 2005企业版的方法(downmoon原作)

    同时安装vs2005团队开发版和sql 2005企业版(downmoon原作) 由于微软在vs2005vsts团队开发版中集成了sql 2005 express,而在SQL 2005中又集成了vs2005Express,,所以当很多用户同时安装vs2005团队开发?:?sql2005企业版(downmoon)时,就会出现数据库连接失败的case 请按照如下步骤修改: OK!作者: 邀月

  • ajax与传统web开发的异同点

    AJAX: 什么是AJAX AJAX即"Asynchronous Javascript And XML"(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术. AJAX = 异步 JavaScript和XML(标准通用标记语言的子集). AJAX 是一种用于创建快速动态网页的技术.通过在后台与服务器进行少量数据交换 AJAX 可以使网页实现异步更新,意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新. AJAX的特点 基于Web标准,使用文档对象模

  • Android应用开发之简易、大气音乐播放器实现专辑倒影效果

    今天要实现的功能是实现专辑倒影效果,这个功能已经属于图像处理方面的了,对图像处理我不怎么在行,等一下会介绍一个很实用的工具类,专门用来进行图像处理的.这个工具类不是我写的,我只是拿来用到自己的项目当中,这已经足够了,我已经完美实现我想要的效果. 效果图: < 一个很有用的工具类 /SimpleBeautyMusicPlayer/src/com/wwj/sb/utils/ImageUtil.java package com.wwj.sb.utils; import java.io.ByteArra

  • C#开发答题赢钱游戏(自动答题器)

    一.前言 现在最火的直播游戏,那就是答题赢钱直播了,如百万英雄.芝士超人.花椒直播.冲顶大会等等,这些游戏的玩法都很简单,答对12题即可瓜分奖金了.玩法虽然简单,但是要能完全答对12题难度还是挺高的,毕竟要非常广的知识面! 二.怎么做自动答题 要能自动答题,肯定是要能知道题目及答案了.题目可以从直播界面获取,方法就是OCR或者搞到数据接口了---嘿嘿,都说了简单教你,所以OCR或者分析数据接口这些复杂的操作,我肯定不教你了(我也不会啊^_%)-- 幸好,现在市面上有一些非常有技术"逼格"

  • c# 基于wpf,开发OFD电子文档阅读器

    前言 OFD是国家标准版式文档格式,于2016年生效.OFD文档国家标准参见<电子文件存储与交换格式版式文档>.既然是国家标准,OFD随后肯定会首先在政务系统使用,并逐步推向社会各个方面.OFD是在研究当下各类文件格式后,推出的标准,有如下优点: 1 产权属于自主产权 2 具有便携性:文件小,可压缩比率大.测试显示生成的文件体量比PDF还要小. 3 具有开放性:易于入门,对于使用者来说更具开放性. 4 具有扩展性:预留了可扩展入口和自定义标引,设置了非接触式引用机制,为特性化提供支持. 5 呈

  • ASP.NET AJAX 1.0 RC开发10分钟图解

    开发环境:VS2005+ASP.NET AJAX 1.0 RC 首先下载ASP.NET AJAX 1.0 RC安装文件,完成安装后即可进行我们的AJAX之旅了. 1.打开VS2005,点击"新建"-"文件"-"网站",选择"ASP.Net-AJAX Enabled Web Site"模板,这个模板是我们安装ASP.NET AJAX 1.0 RC后多出来的模板 2.可以看到左侧工具箱多了一个AJAX Extensions,下面包

  • AJAX技术框架及开发工具

    常见的AJAX框架有: DWR - Web Remoting Buffalo - Web Remoting (based on prototype) prototype - JS OO library openrico - JS UI component (based on prototype) dojo - JS library and UI component qooxdoo - JS UI component (C/S Style) YUL - JS UI component 其中关于DW

  • AJAX实践DWR篇

    DWR(Direct Web Remoting)是一个WEB远程调用框架.利用这个框架可以让AJAX开发变得很简单.利用DWR可以在客户端利用JavaScript直接调用服务端的Java方法并返回值给JavaScript就好像直接本地客户端调用一样(DWR根据Java类来动态生成JavaScrip代码).它的最新版本DWR0.6添加许多特性如:支持Dom Trees的自动配置,支持Spring(JavaScript远程调用spring bean),更好浏览器支持,还支持一个可选的commons-

随机推荐