PHP Conference Japan 2024

DOMXPath::registerPhpFunctions

(PHP 5 >= 5.3.0, PHP 7, PHP 8)

DOMXPath::registerPhpFunctions註冊 PHP 函式作為 XPath 函式

說明

public DOMXPath::registerPhpFunctions(string|array|null $restrict = null): void

這個方法允許在 XPath 表達式中使用 PHP 函式。

參數

restrict

使用此參數可以僅允許從 XPath 呼叫特定函式。

此參數可以是以下其中一種:字串(函式名稱)、索引式 陣列(包含函式名稱),或者關聯式 陣列(鍵為函式名稱,關聯的值為 可呼叫物件)。

回傳值

不回傳任何值。

更新日誌

版本 說明
8.4.0 現在可以在使用帶有 陣列項目的 restrict 時,使用 可呼叫物件 作為回呼。

範例

以下範例使用 book.xml,其中包含以下內容

範例 #1 book.xml

<?xml version="1.0" encoding="UTF-8"?>
<books>
 <book>
  <title>PHP Basics</title>
  <author>Jim Smith</author>
  <author>Jane Smith</author>
 </book>
 <book>
  <title>PHP Secrets</title>
  <author>Jenny Smythe</author>
 </book>
 <book>
  <title>XML basics</title>
  <author>Joe Black</author>
 </book>
</books>

範例 #2 使用 php:functionStringDOMXPath::registerPHPFunctions()

<?php
$doc
= new DOMDocument;
$doc->load('book.xml');

$xpath = new DOMXPath($doc);

// 註冊 php: 命名空間(必要)
$xpath->registerNamespace("php", "https://php.dev.org.tw/xpath");

// 註冊 PHP 函式(無限制)
$xpath->registerPHPFunctions();

// 對書名呼叫 substr 函式
$nodes = $xpath->query('//book[php:functionString("substr", title, 0, 3) = "PHP"]');

echo
"找到 {$nodes->length} 本以 'PHP' 開頭的書:\n";
foreach (
$nodes as $node) {
$title = $node->getElementsByTagName("title")->item(0)->nodeValue;
$author = $node->getElementsByTagName("author")->item(0)->nodeValue;
echo
"$title by $author\n";
}

?>

以上範例的輸出結果類似如下:

Found 2 books starting with 'PHP':
PHP Basics by Jim Smith
PHP Secrets by Jenny Smythe

範例 #3 使用 php:functionDOMXPath::registerPHPFunctions()

<?php
$doc
= new DOMDocument;
$doc->load('book.xml');

$xpath = new DOMXPath($doc);

// 註冊 php: 命名空間(必要)
$xpath->registerNamespace("php", "https://php.dev.org.tw/xpath");

// 註冊 PHP 函式(僅 has_multiple)
$xpath->registerPHPFunctions("has_multiple");

function
has_multiple($nodes) {
// 如果有多位作者,則回傳 true
return count($nodes) > 1;
}
// 篩選有多位作者的書籍
$books = $xpath->query('//book[php:function("has_multiple", author)]');

echo
"有多位作者的書籍:\n";
foreach (
$books as $book) {
echo
$book->getElementsByTagName("title")->item(0)->nodeValue . "\n";
}

?>

以上範例的輸出結果類似如下:

Books with multiple authors:
PHP Basics

範例 #4 使用 可呼叫 類型的 DOMXPath::registerPHPFunctions()

<?php
$doc
= new DOMDocument;
$doc->load('book.xml');

$xpath = new DOMXPath($doc);

// 註冊 php: 名稱空間(必要)
$xpath->registerNamespace("php", "https://php.dev.org.tw/xpath");

// 註冊 PHP 函式(僅 has_multiple)
$xpath->registerPHPFunctions(["has_multiple" => fn ($nodes) => count($nodes) > 1]);

// 過濾有多位作者的書籍
$books = $xpath->query('//book[php:function("has_multiple", author)]');

echo
"有多位作者的書籍:\n";
foreach (
$books as $book) {
echo
$book->getElementsByTagName("title")->item(0)->nodeValue . "\n";
}

?>

以上範例的輸出結果類似如下:

Books with multiple authors:
PHP Basics

另請參閱

新增註釋

使用者提供的註釋

此頁面沒有使用者提供的註釋。
To Top