概览
该库主要用于处理来自 DataProviders 和 Modifiers 中的 UI 组件的数据,它们实际上是解析关联数组中的 XML 文件的复杂过程的一部分。
METHOD DESCRIPTION
exists 检查节点是否存在于给定的关联数组中
find 在嵌套数组中查找节点并保存其索引和父节点引用
findPaths 获取具有指定索引的元素的匹配路径。
get 返回路径末尾的键(或节点)的值。如果找不到该节点,则返回 null。
move 将一个值从一个路径移动到另一个路径
merge 将值与节点合并并返回修改后的数据。如果可能和必要,填充嵌套数组。
remove 移除一个节点并返回修改后的数组。
replace 更新现有节点并返回修改后的数组
set 将值设置到节点中并返回修改后的数据。
slicePath 检索指定路径的切片。
示例:
以下示例显示如何使用 LayoutProcessor 实现将自定义字段添加到结帐帐单地址。
<?php
/**
* Process js Layout of block
*
* @param array $jsLayout
*
* @return array
*/
public function process($jsLayout)
{
if (isset($jsLayout['components']['checkout']['children']['steps']['children']['shipping-step']
['children']['shippingAddress']['children']['shipping-address-fieldset']['children'])
) {
$fields = $jsLayout['components']['checkout']['children']['steps']['children']['shipping-step']
['children']['shippingAddress']['children']['shipping-address-fieldset']['children'];
}
}
为了更清晰地实现上一个示例,请使用 Magento\Framework\Stdlib\ArrayManager 库来消除重复检查并获取所需的数组。
<?php
use Magento\Framework\Stdlib\ArrayManager;
...
/**
* @var ArrayManager
*/
private $arrayManager;
/**
* SomeClass constructor.
*
* @param ArrayManager $arrayManager
*/
public function __construct(ArrayManager $arrayManager)
{
$this->arrayManager = $arrayManager;
}
/**
* Process js Layout of block
*
* @param array $jsLayout
*
* @return array
*/
public function process($jsLayout): array
{
$path = 'components/checkout/children/steps/children/shipping-step/children/shippingAddress/children/shipping-address-fieldset/children';
if ($fields = $this->arrayManager->get($path, $jsLayout)) {
...
}
...
}
...
本文来源: Magento2.x企业级开发实战