XSLT for-each循环怎么使用

XSLT的用于遍历节点集合,需指定select属性(XPath表达式),内部上下文自动切换为当前节点,用position()获取序号,作用域限于块内,空选择静默跳过。

XSLT 的 是最常用的遍历工具,本质是“对选中的每个节点执行一次模板内容”,不带内置计数变量,也不改变全局上下文,用对了很简洁,用错了容易嵌套混乱。

核心写法就一条规则

必须带 select 属性,值是一个 XPath 表达式,指向你要遍历的节点集合:

  • → 遍历当前上下文下的所有 book 元素
  • → 只取前 5 个 cd 节点
  • → 遍历当前元素的 idclass 两个属性(联合轴)

循环里怎么取当前节点的内容

内部,上下文节点自动切换为当前被遍历的节点,所以:

  • → 输出当前节点的字符串值(文本内容)
  • → 输出当前节点下子元素 title 的文本
  • → 向上查父节点的 category 属性
  • → 基于当前节点做条件判断

想加序号?别手写变量,用 position() 就行

XSLT 没有传统 for 循环的 i++,但 position() 函数天然返回当前迭代位置(从 1 开始):

  • → 输出 1、2、3…
  • → 输出 A.、B.、C.…(更语义化,支持嵌套编号)
  • 组合用:

常见踩坑提醒

  • 不能在 外面直接引用循环内定义的 —— 它的作用域仅限该 for-each 块内部
  • 不要试图在 for-each 里“修改”当前 XML 结构 —— XSLT 是函数式语言,只生成新输出,不变更源文档
  • 如果需要复杂逻辑(比如递归处理子树),优先用 + 模板匹配,而不是硬套多层 for-each
  • select 表达式为空时,整个 for-each 块静默跳过,不会报错也不会渲染内容

基本上就这些。写熟了 select + position() + . 这三个点,90% 的列表场景都能干净搞定。