Класс RecursiveCallbackFilterIterator
(PHP 5 >= 5.4.0, PHP 7)
Введение
Обзор классов
Примеры
Callback-функция может принимать до трех аргументов: текущий элемент, текущий ключ и итератор, соответственно.
Пример #1 Доступные аргументы callback-функции
<?php
/**
* Callback-функция для RecursiveCallbackFilterIterator
*
* @param $current Значение текущего элемента
* @param $key Ключ текущего элемента
* @param $iterator Итератор, который фильтруется
* @return boolean TRUE для приема текущего элемента или FALSE - в ином случае.
*/
function my_callback($current, $key, $iterator) {
// Здесь ваш код фильтрации
}
?>
Фильтрация рекурсивного итератора обычно включает в себя два условия.
Первое заключается в том, чтобы разрешить рекурсию. Callback-функция должна возвращать true
,
если текущий элемент итератора имеет потомков.
Второе - это нормальное условие фильтра, например, проверка размера файла или расширения,
как в примере ниже.
Пример #2 Простой пример рекурсивного обратного вызова
<?php
$dir = new RecursiveDirectoryIterator(__DIR__);
// Фильтр больших файлов ( > 100MB)
$files = new RecursiveCallbackFilterIterator($dir, function ($current, $key, $iterator) {
// Разрешить рекурсию
if ($iterator->hasChildren()) {
return TRUE;
}
// Проверка больших файлов
if ($current->isFile() && $current->getSize() > 104857600) {
return TRUE;
}
return FALSE;
});
foreach (new RecursiveIteratorIterator($files) as $file) {
echo $file->getPathname() . PHP_EOL;
}
?>
Содержание
- RecursiveCallbackFilterIterator::__construct — Создает объект класса RecursiveCallbackFilterIterator на основе объекта RecursiveIterator
- RecursiveCallbackFilterIterator::getChildren — Возвращает дочерние элементы итератора, хранящегося внутри RecursiveCallbackFilterIterator
- RecursiveCallbackFilterIterator::hasChildren — Проверяет, содержит ли текущий элемент внутреннего итератора дочерние элементы