XML随笔:语法快速入门及当下流行的RSS简析
今天是本人第一次写博客,之前闭门造车闹出过很多笑话,恰巧这几天刚刚重温了一遍XML的知识,决定把XML的知识再来从头到尾的理一遍,感触颇多,今天分享给大家。希望大家能多多注意其中的要点。
1、定义
首先,可能现在问一句博友,XML是什么。相信很多博友都可以回答的很好,官方解释是一种可扩展标记语言。但是,再问大家一句,什么是标志语言,什么是又叫做扩展性,相信基础不是很牢固的博友就可能有点懵圈。
当然如果您了解HTML这门语言的话,相信对标记型语言这个词肯定不陌生。这门语言含有很多的标签,类似于<html>、<input>等等,这些标签呢,都是在HTML自己的规范里面定义好的,而XML则是自己可以定义这些标签。故可扩展型一词由此而来,其实他俩的区别并不仅仅是这么简单。千万不要混淆的是,XML并不是标记语言,他是创建标记语言的源语言(如HTML),另外他还有很多重要的用途。
下面是一个XML的简单事例:
<note>
<to>XIAOBENDAN</to>
<from>BANK</from>
<heading>Reminder</heading>
<body>我想你了</body>
</note>
抛开语法不谈,其实是很浅显的一个note信息,存储了这段信息的制作者以及收件人。
heading这个标签中存放的是这段信息的内容,body这个标签则是正文主题,即想要表达的内容。但是,其实这段文本根本没有做什么功能,仅仅的只是纯文本而已,可以处理文本文件的程序都可以毫不费力的去处理这个XML文件。
2、XML的作用
当初设计XML这门语言是用作web数据传输和交互的工具,说白了就是实现信息交互的一个媒介,可能有人又要问了,既然有了HTML语言,为什么还需要再设置一个XML语言呢。HTML和XML都含有标签,有着相似的语法,都是用标记来描述网页中的内容。
其实,最大的不同是:HTML语言作为构成网页的一部分,他把数据和显示混在一起,既当爹又当妈。而XML则是仅仅只有存储数据的功能,他不能描述网页具体的外观和内容,他只是描述数据的数据形式和结构,他把数据和显示分开,这也是本质的区别!
而正是这种区别,让XML在网络应用和信息传输上面具有高兼容性,方便并且可扩展。
3、XML需要格式最重要的部分
借鉴了HTML格式不严谨带来的诸多问题之后,XML有自己编写的严格的规范(当然也不是很多。。)。
首先我们来看一段HTML的语句:
<html>
<BOdy>
<p>hr 标签定义水平线:</p>
<hr />
<p>这是段落。</p>
<HR />
<p>这是段落。</p>
<hr />
<font color = red>sss</font>
</bodY>
</html>
在XML文档中,代码基本都是错误的,因为XML编写有很严格的规定:
1、所有的标记都有一个相应的合理的结束标记。
2、所有的XML标记都必须合理的嵌套。
3、所有的XML标记都是区分大小写的。
4、所有的标记的属性必须以" "括起来。
所以,上列语句在XML中应该这样编写:
<html>
<BOdy>
<p>hr 标签定义水平线:</p>
<hr />
<p>这是段落。</p>
<HR />
<p>这是段落。</p>
<hr />
<font color = red>sss</font>
</bodY>
</html>
另外,XML的标记也必须遵循下列规则:
1、名字中可以包含数字字母及其他字符。
2、名字不能以数字或者下划线(_)开头。
3、名字中不能以XML开头。
4、名字中不能包含空格。
4、结语
XML这门语言是web中最重要的几门语言之一,想要精通webservices和网络传输协议,这是必须要攻克的一道门槛。今天暂时给博友们介绍一下XML这门语言是什么以及他的作用,然后又介绍了他的标签的命名规范以及与HTML语言的几点不同之处。谢谢大家的阅读,希望有不对的地方,在下面评论区帮小生指出来,下一篇将会介绍RSS阅读器的知识,鄙人打算做一个自己的RSS阅读器,是用C#做的,会把每天遇到的问题以及思路分享给大家。
本人王银行,现在在程序员的路上算是刚刚起步,最近由于公司需要,慢慢接触到webservices和socket这两方面,之前一直没有细细的认真去钻研。当我从键盘上敲下每一个字的时候,都感觉在与读者亲密的交谈,今天是生平第一次写属于自己的博客,发表自己的看法。以后会时常把自己平时所犯的错误及吸取的教训写到博客园上,希望可以与博友们一起进步,谢谢!!
转载请声明,谢谢!
XML随笔:语法快速入门及当下流行的RSS简析的更多相关文章
- Objective-C基础语法快速入门
Objective-C基础语法快速入门 2010-11-04 16:32 折酷吧 zheku8 字号:T | T 假如我们对面向对象的思维已经C语言都很熟悉的话,对于我们学习Objective-C将会 ...
- Less 语法快速入门
Less 语法快速入门 Less 是一门 CSS 预处理语言其可以运行在 Node 或浏览器端. 它将传统的 css 样式结构单一的排版顺序进行了优化,让我们可以通过层级嵌套的方式将 css 类名与H ...
- T4语法快速入门
1.什么是T4? T4,即4个T开头的英文字母组合:Text Template Transformation Toolkit.T4(Text Template Transformation Toolk ...
- shell语法快速入门(1)
#得到绝对路径 DIR=$(cd `dirname $0`;pwd) $DIR/file.txt #去掉#注释 egrep -v "(#|^$)" /etc/zabbix/zabb ...
- python语法快速入门(1)
http://www.runoob.com/python/python-tutorial.html Python 是一种解释型语言: 这意味着开发过程中没有了编译这个环节.类似于PHP和Perl语言 ...
- Ruby 语法快速入门
作用域:指的是类,模块,方法 常量:无需指定类型,全大写 FANS = 100 puts "We have" + FANS.to_s + "fans" 变量 局 ...
- Markdown 语法快速入门手册
Markdown 是一种轻量级标记语言,能将文本换成有效的XHTML(或者HTML)文档,它的目标是实现易读易写,成为一种适用于网络的书写语言. Markdown 语法简洁明了,易于掌握,所以用它来写 ...
- Vue3语法快速入门以及写一个倒计时组件
Vue3写一个倒计时组件 vue3 beta版本发布已有一段时间了,文档也大概看了一下,不过对于学一门技术,最好的方法还是实战,于是找了一个比较简单的组件用vue3来实现,参考的是vant的count ...
- Python3基础语法快速入门
01 Python 简介 Python 是一种高层次的结合了解释性.编译性.互动性和面向对象的脚本语言.Python 由 Guido van Rossum 于 1989 年底在荷兰国家数学和计算机科学 ...
随机推荐
- OneZero第三周第三次站立会议(2016.4.6)
1. 时间: 13:05--13:15 共计10分钟. 2. 成员: X 夏一鸣 * 组长 (博客:http://www.cnblogs.com/xiaym896/), G 郭又铭 (博客:http ...
- Python常见错误:IndexError: list index out of range
用python写脚本查询字典时,在遍历字典时循环到某一项时老是报错 出现这种错误有两种情况: 第1种可能情况 list[index]index超出范围 第2种可能情况 list是空值就会出现 In ...
- 组合数问题(NOIP2016)
题目链接:组合数问题 这道题可以算当年第二简单的. 这里要用到两个技巧: 用杨辉三角递推计算组合数 运用前缀和 有了这两点,这道题就出来了. 我们先运用杨辉三角推出题目范围内所能用到的所有组合数,然后 ...
- MySQL中使用SHOW PROFILE命令分析性能的用法整理
show profile是由Jeremy Cole捐献给MySQL社区版本的.默认的是关闭的,但是会话级别可以开启这个功能.开启它可以让MySQL收集在执行语句的时候所使用的资源.为了统计报表,把pr ...
- node 报错:Uncaught Error: Cannot find module "!!../../../node_modules/extract-webpack-plugin/loader.js
问题出在缺少less和less-loader 因为以上模块使用了less解析. 解决方法在dependencies添加 "less": "^2.7.1", & ...
- Conda下安装libsvm
如何在canda下安装libsvm? 版本:Python是2.7 canda2 首先想到的是去Python官网上找libsvm的包,结果并没有. 这是因为libsvm是c语言编写的并不是一个Pytho ...
- 2019.01.14 bzoj2648: SJY摆棋子(kd-tree)
传送门 kd−treekd-treekd−tree模板题. 题意简述:支持在平面上插入一个点,求对于一个点的最近点对. 思路:cdqcdqcdq是一种很不错的分治方法 只是好像码量有点窒息 所以我用了 ...
- 2018.11.05 NOIP模拟 相交(dfs序+bit)
传送门 又TMTMTM考原题真是服. 考虑到两条路径相交一定满足某一条的lcalcalca在另外一条路径上面. 于是分开统计有多少个lcalcalca在当前路径上面以及有多少个路径经过了当前的lcal ...
- openstack查看命令的restful调用形式
[root@cc10 fast-pulsar2]# [root@cc10 fast-pulsar2]# cinder --debug type-create hzb DEBUG:keystonecli ...
- 5.Vue临时上传文件夹
1.在项目目录中,通过npm install multiparty进行安装必要组件npm install multiparty --save-dev 2.app.js中添加app.use(bodyPa ...