以下是XPath字串函式列表 -
序號 | 函式 | 描述 |
---|---|---|
1 | starts-with(string1, string2) |
當第一個字串(string1 )以第二個字串(string2 )開頭時返回true 。 |
2 | contains(string1, string2) |
當第一個字串(string1 )包含第二個字串(string2 )時返回true 。 |
3 | substring(string, offset, length?) |
返回字串的一部分,該部分從偏移量(offset )開始,直到提供的長度(length )。 |
4 | substring-before(string1, string2) |
返回在第一次出現string2 之前的string1 部分。 |
5 | substring-after(string1, string2) |
返回在第一次出現string2 之後的string1 部分。 |
6 | string-length(string) |
以字元形式返回字串的長度。 |
7 | normalize-space(string) |
修剪字串中的前導和尾隨空格。 |
8 | translate(string1, string2, string3) |
返回在string1 中,被string2 任何匹配字元替換為string3 中的字元後。 |
9 | concat(string1, string2, ...) |
連線所有字串(string1 ,string2 ,... )。 |
10 | format-number(number1, string1, string2) |
將string1 應用為格式字串後,返回number1 的格式化版本。 string2 是可選的區域設定字串。 |
此範例通過疊代每個學生建立一個<student>
元素的表,其中包含名稱和名稱長度。 它在連線名字和姓氏後計算學生姓名的長度,然後列印學生的詳細資訊。
檔案:students.xml -
<?xml version = "1.0"?>
<?xml-stylesheet type = "text/xsl" href = "students.xsl"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Su</lastname>
<nickname>MaXX</nickname>
<marks>88</marks>
</student>
<student rollno = "493">
<firstname>Vaneet</firstname>
<lastname>Lee</lastname>
<nickname>Vicky</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Wong</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
檔案:students.xsl -
<?xml version = "1.0" encoding = "UTF-8"?>
<xsl:stylesheet version = "1.0"
xmlns:xsl = "http://www.w3.org/1999/XSL/Transform">
<xsl:template match = "/">
<html>
<body>
<h2>Students</h2>
<table border = "1">
<tr bgcolor = "#9acd32">
<th>Name</th>
<th>Length of Name</th>
</tr>
<xsl:for-each select = "class/student">
<tr>
<td><xsl:value-of select = "concat(firstname,' ',lastname)"/></td>
<td><xsl:value-of select = "string-length(concat(firstname,' ',lastname))"/></td>
</tr>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
在瀏覽器中,開啟上面範例程式碼檔案:student.xml ,效果如下所示 -