XML:基础

一、语法

基本结构:

实例一:

XML 复制代码
<?xml version="1.0" encoding="ISO-8859-1"?>
<note data="2008/08/08">
<to>George</to>
<from>John</from>
<heading>Reminder</heading>
<body>Don't forget the meeting!</body>
</note>

XML 文档编写前要使用文档申明,声明要给出具体编码,必须有根元素,其元素必须有闭标签,且对大小写敏感。XML元素的属性名也可以自定义,但属性值必须要用引号括起来。

要注意的是元数据(有关数据的描述)应当存储为属性,而数据本身应当存储为元素,尽量减少使用属性,因为属性不易拓展。

实体引用:

实例二:

XML 复制代码
<?xml version="1.0" encoding="ISO-8859-1"?>
<note data="2008/08/08">
<to>George</to>
<from>John</from>
<heading>Reminder</heading>
<message>if salary &lt; 1000 then</message>
<body>Don't forget the meeting!</body>
</note>

在XML中如果把"<"符号放在元素中,会被解释器当成新的元素开始,为了避免这个错误,用实体引用来代替 "<" 字符,以下是5个预定义的实体引用。

|---------|--------|--------|
| 实体 | 符号 | 名称 |
| &lt; | < | 小于 |
| &gt; | > | 大于 |
| &amp; | & | 和号 |
| ' | ' | 单引号 |
| &quot; | " | 引号 |

二、命名规则

XML元素命名有以下规则:

  • 不能以数字或标点符号开头
  • 不能以字符xml开头
  • 不能包含空格
  • 使名称具有描述性,可以使用下划线的命名方式

三、 命名冲突

当两个不同文档使用相同的元素名称时,就会发送命名冲突。

例:

文档一:

XML 复制代码
<table>
   <tr>
   <td>Apples</td>
   <td>Bananas</td>
   </tr>
</table>

文档二:

XML 复制代码
<table>
   <tr>
   <td>Apples</td>
   <td>Bananas</td>
   </tr>
</table>

当两个xml文档被一起使用时候,table标签则会发生冲突。

1.前缀

通过添加前缀避免冲突

文档一:

XML 复制代码
<h:table>
   <h:tr>
   <h:td>Apples</h:td>
   <h:td>Bananas</h:td>
   </h:tr>
</h:table>

文档二:

XML 复制代码
<h:table>
   <h:tr>
   <h:td>Apples</h:td>
   <h:td>Bananas</h:td>
   </h:tr>
</h:table>

2.命名空间(xmlns属性)

语法:xmlns:namespace-prefix="namespaceURI",其中namespace-prefix是自定的,可以不写,不写代表默认命名空间,namespaceURI是一个可访问的url,具体内容为XML Schema定义,用来定义xml文档的结构,以此防止冲突。

文档一:

XML 复制代码
<table xmlns="http://www.w3.org/TR/html4/">
   <tr>
   <td>Apples</td>
   <td>Bananas</td>
   </tr>
</table>

文档二:

XML 复制代码
<table xmlns="http://www.w3school.com.cn/furniture">
   <name>African Coffee Table</name>
   <width>80</width>
   <length>120</length>
</table>
相关推荐
天渺工作室5 小时前
实现一个adblock/adblock plus等浏览器广告拦截器检测插件
前端·javascript
阳光是sunny5 小时前
Vue 项目怎么做用户行为全链路监控?轻量插件方案详解
前端·面试·架构
ZhengEnCi5 小时前
Q04-Vite禁用CSS代码分割-解决生产环境样式加载顺序混乱问题
前端·vue.js·vite
九酒6 小时前
AI Agent 开发踩坑记:口播功能非得用 APP 原生实现吗?
前端·人工智能·agent
Jackson__6 小时前
做了一段时间的AI coding后,我终于搞清了 CLI 和 MCP 的区别
前端·agent·ai编程
IT_陈寒9 小时前
JavaScript项目实战经验分享
前端·人工智能·后端
用户479492835691510 小时前
6w star,GitHub 趋势第一的 Ponytail,这个agent插件到底在火什么
前端·后端
吃饱了得干活10 小时前
Spring Cloud Gateway 微服务网关:路由、断言、过滤器
java·spring cloud
薛定喵的谔11 小时前
我开源了一个精致的 Next.js 博客模板:Skyplume
前端·前端框架·next.js
张龙68712 小时前
构建生产级 AI Agent:工具调用与记忆架构实战指南
前端