starts-with()函数用于匹配字符串前缀,需结合name()、.或@attr使用:匹配元素名用starts-with(name(), 'div'),匹配文本用starts-with(., 'Error'),匹配属性用starts-with(@id, 'user');注意大小写敏感且参数须为字符串。
在XPath中,用 starts-with() 函数可以精准匹配节点名(或文本内容)以指定字符串开头的情况。它常用于元素名、属性值或文本节点的筛选。
注意:XPath本身不能直接判断“元素名是否以某字符开头”,因为 starts-with() 作用于字符串值(如 name() 或 local-name() 的返回结果),而非标签名本身。所以需结合 name() 函数使用:
//*[starts-with(name(), 'div')] —— 选所有标签名以 "div" 开头的元素(如 、)
-
//*[starts-with(local-name(), 'a')] —— 更推荐,避免命名空间干扰,选本地名以 "a" 开头的元素(如 、)
选择文本内容以特定字符开头的节点
这是最常见用法,直接对节点的字符串值做判断:
-
//p[starts-with(text(), 'Hello')] —— 选第一个文本子节点以 "Hello" 开头的
-
//span[starts-with(., 'Error')] —— . 表示当前节点的合并文本(含所有子文本),更稳妥,适合有内联标签的场景
选择属性值以特定字符开头的节点
配合 @属性名 使用即可:
-
//input[starts-with(@id, 'user')] —— 选 id 属性以 "user" 开头的 元素(如 id="username"、id="userEmail")
-
//*[@class and starts-with(@class, 'btn-')] —— 先确保 @class 存在,再判断是否以 "btn-" 开头(避免空值报错)
注意事项和常见坑
starts-with() 区分大小写,且只支持字符串前缀匹配,不支持通配符或正则:
- 想忽略大小写?XPath 1.0 无内置函数,需靠外部处理;XPath 2.0+ 可用
lower-case() 包裹,如 starts-with(lower-case(@id), 'user')
-
text() 只取第一个文本子节点,若元素含多个文本或嵌套标签,建议用 . 替代
- 函数参数必须是字符串,
starts-with(@data-id, 12
3) 会报错,应写成 starts-with(@data-id, '123')
基本上就这些。掌握 starts-with() 配合 name()、. 和 @attr,就能覆盖大多数“开头匹配”需求。