XSL入门教程从零开始快速掌握
一. XSL入门
1. XSL---XML的样式表
玩过HTML的朋友都知道,它有一套预设好的标签(tags),比如
就是另起一行,
就是标题字体。这套规则,所有浏览器都心知肚明,知道怎么解析和呈现。可到了XML这里,情况就完全不同了——它没有固定的标签!我们可以创建任何自己需要的标识。这样一来,问题就出现了:一个
| Title | Artist |
|---|---|
在这段代码里,有几个核心角色登场了。元素好比一个“循环指针”,它的任务是锁定XML文档里哪些元素需要按照后续的模板循环显示。它的select属性,定义了源文件中的目标元素路径,这种类似文件目录的写法,就是所谓的XML Pattern(模式)。而元素,则负责在当前位置插入指定子元素的内容。
细心的你可能发现了,XSL样式表本身也是一个规范的XML文档,所以它开头也有XML声明。元素则是在宣告:“这是一个样式表文件。”至于这句,意思是XML源文档的根节点从这里开始匹配。
最后,如何让浏览器知道该用这个样式表呢?很简单,只需在原始的XML文档头部加上一行指引(看下面代码第2行),浏览器就能精准地执行转换,输出HTML文件。
Empire Burlesque
Bob Dylan
USA
Columbia
10.90
1985
三. XSL--在客户端的实现
1. Ja vaScript解决方案
上面我们介绍了通过在XML头部引入XSL样式表,让浏览器自动完成转换的方法。这在多数情况下工作良好,但它的软肋在于:如果浏览器本身不支持XML,整个方案就失效了。
有没有更全面、适应性更强的办法呢?答案是使用Ja vaScript来主导这场转换。不过,要启用Ja vaScript方案,它需要具备两个关键能力:
首先,允许Ja vaScript代替浏览器去做详细的兼容性检测;其次,能够让我们根据不同需求、面对不同浏览器时,动态切换使用不同的样式表。
而这恰恰是XSL设计的初衷之一。XSL生来就是为了实现不同格式间的自由转换,以适应千差万别的浏览器环境和用户需求。可以说,在客户端执行XSL转换,本就是未来浏览器的重要使命。
2. 一个具体的实例
光说不练假把式,我们来看具体如何操作。还是用回刚才那个CD目录的XML文档(cd_catalog.xml),部分内容如下:
Empire Burlesque
Bob Dylan
USA
Columbia
10.90
1985
.
.
.
以及之前那个完整的XSL文件(cd_catalog.xsl)。此刻,XML文件还没有关联XSL,也还没变成HTML。
真正的魔法,藏在下面这段使用Ja vaScript的HTML代码里:
当然,如果你对Ja vaScript还不熟悉,可能需要先补补课。这段代码的逻辑非常清晰:第一块创建了一个Microsoft XML解析器对象,把XML文档读进内存;第二块如法炮制,创建另一个对象并导入XSL文档;最后那行代码,则是命令解析器使用XSL对XML进行转换,并将最终结果直接输出到HTML页面上。
如此一来,即使浏览器本身对XML支持有限,我们也能通过Ja vaScript这个“中间人”,完美实现数据到页面的华丽转身。
来源:https://www.jb51.net/article/2430.htm
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
Notepad++批量修改文件后缀名脚本使用教程
Notepad++无法直接批量修改文件后缀,通常需借助插件调用系统命令实现。对于简单情况,可使用NppExec插件配合cmd命令处理;若涉及多层目录或复杂条件,则建议编写Python脚本进行递归操作。需注意文件占用可能导致失败,且修改后缀可能影响系统关联和编辑器识别。
Linux下Rust代码编译问题排查与解决指南
在Linux中,如果Rust编译出错,你可以按照以下步骤进行排查和解决: 阅读错误信息: Rust编译器给出的错误信息通常非常详实,不仅会标明错误类型,还会精确到文件和行号。第一步,务必静下心来仔细读一读这些提示,它们往往能直接帮你定位到问题的根源。 检查代码语法: Rust的语法规则相对严谨,有时
Ubuntu系统JSP代码优化方法与实战技巧
Ubuntu上JSP代码与运行时一体化优化指南 想让老派的JSP应用在Ubuntu上跑得又快又稳?这事儿不单是写写代码就行,得从代码、配置到运行时整个链路都做通盘考虑。下面这份优化指南,就是给这类项目开的一剂综合药方。 一 代码与页面层优化 这一层的核心思路是“各司其职”,让前端页面和后端逻辑都回归
Docker与常见技术栈集成方法及实践指南
Linux Docker 的常见集成方式 玩转Docker容器,如果只是单打独斗,那可有点小瞧它了。它真正的潜力,往往在于与生态中其他“伙伴”的紧密协作。通过灵活的集成,它能迸发出远超单个工具的能量。下面这几种常见的组合拳,或许能帮你打开新思路。 1 Kubernetes:不只是编排,更是自动化管
Linux vsFTP性能评测与主流FTP服务器软件对比分析
Linux vsftpd 性能对比与选型建议 结论与定位 当我们谈论面向高并发、长时间稳定运行的生产级FTP服务时,一个名字总是绕不开:vsftpd。在相同的硬件与网络舞台上,这款服务器以其极致的轻量与稳定,展现了令人印象深刻的实力。社区的多项测试与资料显示,它在单机(非集群)部署下就能轻松撑起40
热门专题
- 日榜
- 周榜
- 月榜
1
2
3
4
5
6
7
8
9
10
1
2
3
4
5
6
7
8
9
10
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

