codecamp

RSS 语法

RSS 语法

本节介绍了 RSS 语法,并且通过实例来讲解。

RSS 2.0 的语法很简单,也很严格。


RSS 如何工作

RSS 用于在网站间分享信息。

使用 RSS,您在名为聚合器的公司注册您的内容。

步骤之一是,创建一个 RSS 文档,然后使用 .xml 后缀来保存它。然后把此文件上传到您的网站。接下来,通过一个 RSS 聚合器来注册。每天,聚合器都会到被注册的网站搜索 RSS 文档,校验其链接,并显示有关 feed 的信息,这样客户就能够链接到使他们产生兴趣的文档。

提示:请在 RSS 发布 这一节浏览免费的 RSS 聚合器服务。


RSS 实例

RSS 文档使用一种简单的自我描述的语法。

让我们看一个简单的 RSS 文档:

<?xml version="1.0" encoding="ISO-8859-1" ?>
<rss version="2.0">

<channel>
  <title>W3Cschools Home Page</title>
  <link>http://www.w3cschools.com</link>
  <description>Free web building tutorials</description>
  <item>
    <title>RSS Tutorial</title>
    <link>//www.w3cschool.cn/rss</link>
    <description>New RSS tutorial on W3Cschools</description>
  </item>
  <item>
    <title>XML Tutorial</title>
    <link>//www.w3cschool.cn/xml</link>
    <description>New XML tutorial on W3Cschools</description>
  </item>
</channel>

</rss>

文档中的第一行:XML 声明 - 定义了文档中使用的 XML 版本和字符编码。此例子遵守 1.0 规范,并使用 ISO-8859-1 (Latin-1/West European) 字符集。

下一行是标识此文档是一个 RSS 文档的 RSS 声明(此例是 RSS version 2.0)。

下一行含有 <channel> 元素。此元素用于描述 RSS feed。

<channel> 元素有三个必需的子元素:

  • <title> - 定义频道的标题。(比如 w3cschool 首页)
  • <link> - 定义到达频道的超链接。(比如 www.w3cschool.cn)
  • <description> - 描述此频道(比如免费的网站建设教程)

每个 <channel> 元素可拥有一个或多个 <item> 元素。

每个 <item> 元素可定义 RSS feed 中的一篇文章或 "story"。

<item> 元素拥有三个必需的子元素:

  • <title> - 定义项目的标题。(比如 RSS 教程)
  • <link> - 定义到达项目的超链接。(比如 //www.w3cschool.cn/rss)
  • <description> - 描述此项目(比如 w3cschool 的 RSS 教程)

最后,后面的两行关闭 <channel> 和 <rss> 元素。


RSS 中的注释

在 RSS 中书写注释的语法与 HTML 的语法类似:

<!-- This is an RSS comment -->

参考:HTML 注释标签


RSS 使用 XML 来编写

因为 RSS 也是 XML,请记住:

  • 所有的元素必许拥有关闭标签
  • 元素对大小写敏感
  • 元素必需被正确地嵌套
  • 属性值必须带引号

相关教程

XML教程

RSS 历史
RSS channel 元素
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }