xml_set_element_handler

(PHP 4, PHP 5, PHP 7, PHP 8)

xml_set_element_handlerEstablece los gestores de inicio y fin de etiqueta XML

Descripción

xml_set_element_handler(XMLParser $parser, callable|string|null $start_handler, callable|string|null $end_handler): true

Establece los gestores de inicio y fin del analizador XML parser.

start_handler es llamado cuando un nuevo elemento XML es abierto. end_handler es llamado cuando un elemento XML es cerrado.

Parámetros

parser

El analizador XML.

start_handler

Si null se pasa, el controlador se reinicia a su estado por omisión.

Advertencia

Una cadena vacía también reiniciará el controlador, sin embargo esta funcionalidad está deprecada a partir de PHP 8.4.0.

Si handler es un callable, el callable se define como el controlador.

Si handler es una string, puede ser el nombre de un método de un objeto definido con xml_set_object().

Advertencia

Esta funcionalidad está deprecada a partir de PHP 8.4.0.

Advertencia

A partir de PHP 8.4.0, se verifica la validez del callable durante la configuración del controlador, y no en el momento de su llamada. Esto significa que xml_set_object() debe ser llamado antes de definir un método como cadena como devolución de llamada. Sin embargo, como este comportamiento también está deprecado a partir de PHP 8.4.0, se recomienda utilizar un callable adecuado para el método.

La firma del gestor debe ser:

start_element_handler(XMLParser $parser, string $name, array $attributes): void
parser
El analizador XML que llama al controlador.
name
Contiene el nombre del elemento que provocó la llamada del gestor. Si el analizador gestiona la casse, este elemento estará en mayúsculas.
attributes
Un array asociativo con los atributos del elemento. El array estará vacío si no hay atributos. Las claves de este array serán los nombres de los atributos, y los valores serán los valores correspondientes de los atributos. Los nombres de los atributos estarán en mayúsculas si el analizador gestiona la casse. Los valores de los atributos permanecerán inalterados. El orden en el que attributes es recorrido es idéntico al orden en el que los atributos fueron declarados.

end_handler

Si null se pasa, el controlador se reinicia a su estado por omisión.

Advertencia

Una cadena vacía también reiniciará el controlador, sin embargo esta funcionalidad está deprecada a partir de PHP 8.4.0.

Si handler es un callable, el callable se define como el controlador.

Si handler es una string, puede ser el nombre de un método de un objeto definido con xml_set_object().

Advertencia

Esta funcionalidad está deprecada a partir de PHP 8.4.0.

Advertencia

A partir de PHP 8.4.0, se verifica la validez del callable durante la configuración del controlador, y no en el momento de su llamada. Esto significa que xml_set_object() debe ser llamado antes de definir un método como cadena como devolución de llamada. Sin embargo, como este comportamiento también está deprecado a partir de PHP 8.4.0, se recomienda utilizar un callable adecuado para el método.

La firma del gestor debe ser:

end_element_handler(XMLParser $parser, string $name): void
parser
El analizador XML que llama al controlador.
name
Contiene el nombre del elemento que provocó la llamada del gestor. Si el analizador gestiona la casse, este elemento estará en mayúsculas.

Valores devueltos

Retorna siempre true.

Historial de cambios

Versión Descripción
8.4.0 Passing a non-callable string to handler is now deprecated, use a proper callable for methods, or null to reset the handler.
8.4.0 The validity of handler as a callable is now checked when setting the handler instead of checking when calling it.
8.0.0 parser ahora espera una instancia de XMLParser en lugar de un resource xml.