XLink全称为可扩展链接语言(Extensible Linking Language),是W3C制定的用于在XML文档中创建和操作超链接的规范。和HTML中只能实现简单单向跳转的<a>标签不同,XLink支持更灵活的链接形式,既可以定义基础的单向资源跳转,也能实现多资源关联、链接分组、双向引用等复杂功能,非常适合需要在多个XML文档之间建立关联的场景。
XLink的核心概念
XLink的链接通过XML元素的属性来定义,所有XLink相关的属性都使用固定的命名空间http://www.w3.org/1999/xlink。根据功能复杂度,XLink链接分为两种类型:
- 简单链接:类似HTML的超链接,实现从一个资源到另一个资源的单向跳转,配置简单,适合大多数基础场景。
- 扩展链接:支持多资源关联、链接分组、角色定义等高级功能,适合复杂的资源关联需求。
在XML中使用XLink的前置准备
要在XML文档中使用XLink,首先需要在根元素或者需要使用XLink的元素上声明XLink命名空间。声明方式如下:
<?xml version="1.0" encoding="UTF-8"?> <root xmlns:xlink="http://www.w3.org/1999/xlink"> <!-- 后续XLink相关配置写在这里 --> </root>
这里的xmlns:xlink就是XLink命名空间的声明,后续所有XLink属性都需要加上xlink:前缀才能被正确识别。
创建XLink简单链接
简单链接只需要配置三个核心属性:xlink:type指定链接类型为simple,xlink:href指定链接的目标资源地址,xlink:show指定链接的展示方式。常见的展示方式有两种:
replace:替换当前资源展示目标资源,类似HTML中<a>标签的默认跳转行为。new:在新窗口展示目标资源。
下面是一个简单的XLink简单链接示例,实现点击图书名称跳转到对应的图书详情页:
<?xml version="1.0" encoding="UTF-8"?>
<book_list xmlns:xlink="http://www.w3.org/1999/xlink">
<book>
<book_name xlink:type="simple"
xlink:href="https://ipipp.com/books/101.html"
xlink:show="replace">
XML核心技术详解
</book_name>
<author>张三</author>
<price>69.00</price>
</book>
<book>
<book_name xlink:type="simple"
xlink:href="https://ipipp.com/books/102.html"
xlink:show="new">
XLink实战指南
</book_name>
<author>李四</author>
<price>55.00</price>
</book>
</book_list>
在这个示例中,book_name元素被定义为XLink简单链接,当用户触发该链接时,第一个图书会替换当前页面展示详情,第二个图书会在新窗口打开详情页。
创建XLink扩展链接
扩展链接的功能更丰富,需要设置xlink:type为extended,同时可以包含多个子元素定义不同的链接角色。扩展链接常用的子元素属性包括:
xlink:type="locator":定义链接的资源位置。xlink:type="arc":定义资源之间的跳转关系。xlink:from和xlink:to:指定跳转的源资源角色和目标资源角色。
下面是一个扩展链接的示例,实现从作者信息跳转到其所有著作的列表:
<?xml version="1.0" encoding="UTF-8"?>
<author_info xmlns:xlink="http://www.w3.org/1999/xlink">
<!-- 扩展链接容器 -->
<related_resources xlink:type="extended">
<!-- 源资源:作者信息 -->
<author_loc xlink:type="locator"
xlink:href="https://ipipp.com/authors/zhangsan"
xlink:role="author"
xlink:label="author_zhang" />
<!-- 目标资源:著作列表 -->
<book_list_loc xlink:type="locator"
xlink:href="https://ipipp.com/authors/zhangsan/books"
xlink:role="book_list"
xlink:label="zhang_books" />
<!-- 定义跳转关系:从作者跳转到著作列表 -->
<link_arc xlink:type="arc"
xlink:from="author_zhang"
xlink:to="zhang_books"
xlink:show="replace" />
</related_resources>
<basic_info>
<name>张三</name>
<field>XML技术</field>
</basic_info>
</author_info>
这个扩展链接定义了作者资源和著作列表资源之间的关联关系,当触发链接时就会从作者页面跳转到对应的著作列表页面,还可以继续添加更多的资源位置和跳转关系,实现多资源的交叉关联。
XLink常用属性说明
为了更清晰地理解XLink的属性配置,下面整理了常用属性的说明:
| 属性名 | 适用链接类型 | 说明 |
|---|---|---|
| xlink:type | 所有类型 | 指定链接类型,可选值为simple、extended、locator、arc等 |
| xlink:href | 简单链接、locator | 指定链接的目标资源URI地址 |
| xlink:show | 简单链接、arc | 指定资源的展示方式,可选值为replace、new、embed等 |
| xlink:actuate | 简单链接、arc | 指定链接的触发方式,可选值为onLoad(加载时触发)、onRequest(用户请求时触发) |
| xlink:label | locator、arc | 为资源定义标识,用于扩展链接中关联不同资源 |
注意事项
使用XLink时需要确保XML解析器支持XLink规范,部分老旧的解析器可能无法识别XLink属性。另外XLink的命名空间必须正确声明,否则属性会被当作普通自定义属性处理,无法生效。
如果链接的目标地址是本地资源,xlink:href可以使用相对路径,比如xlink:href="books/detail.xml",指向当前XML文件所在目录下的books文件夹中的detail.xml文件。如果需要引用本地IP地址的资源,比如xlink:href="http://127.0.0.1:8080/data.xml"或者xlink:href="http://192.168.0.1:9090/info.xml",可以直接使用无需修改。