1
0
mirror of https://github.com/php/doc-ru.git synced 2026-04-25 08:18:16 +02:00
Files
archived-doc-ru/reference/array/functions/array-replace-recursive.xml
T
Alexey Pyltsyn 7553327adf array_replace functions: upd
git-svn-id: https://svn.php.net/repository/phpdoc/ru/trunk@345406 c90b9560-bf6c-de11-be94-00142212c4b1
2018-07-29 06:24:05 +00:00

191 lines
6.1 KiB
XML

<?xml version="1.0" encoding="utf-8"?>
<!-- EN-Revision: b7a1a91f896ad48619d023d074f10ba69a514160 Maintainer: shein Status: ready -->
<!-- Reviewed: yes -->
<!-- $Revision$ -->
<refentry xml:id="function.array-replace-recursive" xmlns="http://docbook.org/ns/docbook">
<refnamediv>
<refname>array_replace_recursive</refname>
<refpurpose>Рекурсивно заменяет элементы первого массива элементами переданных массивов</refpurpose>
</refnamediv>
<refsect1 role="description">
&reftitle.description;
<methodsynopsis>
<type>array</type><methodname>array_replace_recursive</methodname>
<methodparam><type>array</type><parameter>array1</parameter></methodparam>
<methodparam choice="opt"><type>array</type><parameter>...</parameter></methodparam>
</methodsynopsis>
<para>
<function>array_replace_recursive</function> заменяет значения массива
<parameter>array1</parameter> на соответствующие по ключам
значения из всех следующих массивов.
Если ключ из первого массива есть во втором, его значение будет заменено
на значение из второго массива. Если ключ есть во втором массиве, но отсутствует в первом,
он будет создан в первом массиве. Если ключ есть только в первом массиве, то он остается как есть.
Если передано несколько массивов, они будут обработаны по порядку, последующие перезаписывают
предыдущие значения.
</para>
<para>
<function>array_replace_recursive</function> - рекурсивная функция: она будет рекурсивно
углубляться в массивы и применять к всем внутренним значениям один и тот
же процесс.
</para>
<para>
Если значение, переданное в первый массив является
скалярным, оно будет заменено значением во второй массив,
которое может быть скалярным значением или массивом.
Если оба значения, переданные в первый массив и во второй массив -
массивы, <function>array_replace_recursive</function> будет заменять их значения рекурсивно.
</para>
</refsect1>
<refsect1 role="parameters">
&reftitle.parameters;
<para>
<variablelist>
<varlistentry>
<term><parameter>array1</parameter></term>
<listitem>
<para>
Массив, элементы которого будут заменены.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>...</parameter></term>
<listitem>
<para>
Необязательно. Массивы, из которых будут браться элементы для замены.
</para>
</listitem>
</varlistentry>
</variablelist>
</para>
</refsect1>
<refsect1 role="returnvalues">
&reftitle.returnvalues;
<para>
Возвращает массив (<type>array</type>) или &null;, если произошла ошибка.
</para>
</refsect1>
<refsect1 role="examples">
&reftitle.examples;
<para>
<example>
<title>Пример использования <function>array_replace_recursive</function></title>
<programlisting role="php">
<![CDATA[
<?php
$base = array('citrus' => array( "orange") , 'berries' => array("blackberry", "raspberry"), );
$replacements = array('citrus' => array('pineapple'), 'berries' => array('blueberry'));
$basket = array_replace_recursive($base, $replacements);
print_r($basket);
$basket = array_replace($base, $replacements);
print_r($basket);
?>
]]>
</programlisting>
&example.outputs;
<screen role="php">
<![CDATA[
Array
(
[citrus] => Array
(
[0] => pineapple
)
[berries] => Array
(
[0] => blueberry
[1] => raspberry
)
)
Array
(
[citrus] => Array
(
[0] => pineapple
)
[berries] => Array
(
[0] => blueberry
)
)
]]>
</screen>
</example>
<example>
<title><function>array_replace_recursive</function> и рекурсивное поведение</title>
<programlisting role="php">
<![CDATA[
<?php
$base = array('citrus' => array("orange") , 'berries' => array("blackberry", "raspberry"), 'others' => 'banana' );
$replacements = array('citrus' => 'pineapple', 'berries' => array('blueberry'), 'others' => array('litchis'));
$replacements2 = array('citrus' => array('pineapple'), 'berries' => array('blueberry'), 'others' => 'litchis');
$basket = array_replace_recursive($base, $replacements, $replacements2);
print_r($basket);
?>
]]>
</programlisting>
&example.outputs;
<screen role="php">
<![CDATA[
Array
(
[citrus] => Array
(
[0] => pineapple
)
[berries] => Array
(
[0] => blueberry
[1] => raspberry
)
[others] => litchis
)
]]>
</screen>
</example>
</para>
</refsect1>
<refsect1 role="seealso">
&reftitle.seealso;
<para>
<simplelist>
<member><function>array_replace</function></member>
<member><function>array_merge_recursive</function></member>
</simplelist>
</para>
</refsect1>
</refentry>
<!-- Keep this comment at the end of the file
Local variables:
mode: sgml
sgml-omittag:t
sgml-shorttag:t
sgml-minimize-attributes:nil
sgml-always-quote-attributes:t
sgml-indent-step:1
sgml-indent-data:t
indent-tabs-mode:nil
sgml-parent-document:nil
sgml-default-dtd-file:"~/.phpdoc/manual.ced"
sgml-exposed-tags:nil
sgml-local-catalogs:nil
sgml-local-ecat-files:nil
End:
vim600: syn=xml fen fdm=syntax fdl=2 si
vim: et tw=78 syn=sgml
vi: ts=1 sw=1
-->