Создает объект RecursiveFilterIterator на основе объекта-итератора RecursiveIterator


(PHP 5 >= 5.1.0)

RecursiveFilterIterator::__construct Создает объект RecursiveFilterIterator на основе объекта-итератора RecursiveIterator

Описание

public RecursiveFilterIterator::__construct ( RecursiveIterator $iterator )

Создает итератор RecursiveFilterIterator на основе RecursiveIterator.

Список параметров

iterator

Объект-итератор RecursiveIterator, элементы которого требуется отфильтровать.

Возвращаемые значения

Эта функция не возвращает значения после выполнения.

Примеры

Пример #1 Пример использования RecursiveFilterIterator()

<?php
class TestsOnlyFilter extends RecursiveFilterIterator {
    public function 
accept() {
        
// текущий элемент пройдет фильтр, если имеет дочерние элементы или
        // его значение начинается со строки "test"
        
return $this->hasChildren() || (strpos($this->current(), "test") !== FALSE);
    }
}

$array    = array("test1", array("taste2""test3""test4"), "test5");
$iterator = new RecursiveArrayIterator($array);
$filter   = new TestsOnlyFilter($iterator);

foreach(new 
RecursiveIteratorIterator($filter) as $key => $value)
{
    echo 
$value "\n";
}
?>

Результатом выполнения данного примера будет что-то подобное:

 test1 test3 test4 test5 

Пример #2 Еще пример с RecursiveFilterIterator()

<?php
class StartsWithFilter extends RecursiveFilterIterator {

    protected 
$word;

    public function 
__construct(RecursiveIterator $rit$word) {
        
$this->word $word;
        
parent::__construct($rit);
    }

    public function 
accept() {
        return 
$this->hasChildren() OR strpos($this->current(), $this->word) === 0;
    }
    
    public function 
getChildren() {
        return new 
self($this->getInnerIterator()->getChildren(), $this->word);
    }
}

$array    = array("test1", array("taste2""test3""test4"), "test5");
$iterator = new RecursiveArrayIterator($array);
$filter   = new StartsWithFilter($iterator"test");

foreach(new 
RecursiveIteratorIterator($filter) as $key => $value)
{
    echo 
$value "\n";
}
?>

Результатом выполнения данного примера будет что-то подобное:

 test1 test3 test4 test5 

Смотрите также

  • RecursiveFilterIterator::getChildren() - Возвращает дочерние элементы внутреннего итератора в виде объекта RecursiveFilterIterator
  • RecursiveFilterIterator::hasChildren() - Проверяет, есть ли у текущего элемента внутреннего итератора дочерние элементы
  • FilterIterator::accept() - Проверяет, является ли текущий элемент итератора допустимым