1csoft/orm-iblock

ORM D7 для инфоблоков битрикса

1.4.2 2020-11-04 13:51 UTC

This package is auto-updated.

Last update: 2024-09-11 00:15:30 UTC


README

当开发者在D7信息块的主题上决定或未决定做什么时,我们不得不想办法应对。这个库不是贝特里克斯模块,通过Composr安装。

它能做什么

  • 按照Entity/DataManager D7的常规语法进行信息块和属性的查询
  • 根据信息块和属性、绑定元素的字段以及这些绑定元素的属性进行筛选(仅当属性设置中指定了绑定信息块的类型和ID时)
  • 既可以像Element::getList一样使用,也可以通过new Query()使用
  • 通过代码或属性ID获取元素的单独属性。
  • 通过OrmIblock\ElementTable::getEntity($iblock_id)构建实体,带有属性或没有属性,然后在Reference字段中使用。
  • 支持信息块v1。

安装

composer require 1csoft/orm-iblock

使用

require_once(<path to vendor/autoload.php>);
use Soft1c\OrmIblock;

$rs = OrmIblock\ElementTable::getList([
	'filter' => [
        'IBLOCK_ID' => $iblock, 
        'PROPERTY.DISTRIBUTION_TYPE_ENUM.XML_ID'=>'ONLINE' // фильтруем записи по XMK_ID списочного св-ва
	],
	'select' => [
		'ID',
		'ADDITIONAL_MIN' =>'PROPERTY.ADDITIONAL_MIN', // HTML св-во
		'PRICES' => 'PROPERTY.PRODUCT_PRICE_REF.PROPERTY.PRISE_FOR', // св-во привяззаного элемента
		'DISTRIBUTION_TYPE' => 'PROPERTY.DISTRIBUTION_TYPE' // списочное св-во - тутвернется только ID варианта списка
	],
	'limit' => 20
]);
while ($item = $rs->fetch()){
	$result[] = $item;
}

dump($result);

在query语法中使用

$q = OrmIblock\ElementTable::query($iblock);
$rs = $q
	->setSelect([
		'ID', 'NAME',
		'DISTRIBUTION_TYPE' => 'PROPERTY.DISTRIBUTION_TYPE_ENUM.VALUE', // получение значения варианта списка
		'DISTRIBUTION_LINK' => 'PROPERTY.DISTRIBUTION_LINK',
		'PREVIEW_PICTURE',
		'SRC' => 'PREVIEW_PICTURE_FILE.PATH', // вернется путь картинки от корня сайта
		'FILE_SIZE' => 'PREVIEW_PICTURE_FILE.FILE_SIZE' // человекопонятный размер файла
	])
	->setFilter([
		'IBLOCK_ID' => $iblock,
		'=ID' => 20071776,
	])
	->setOrder(['ID' => 'ASC'])
;
$result = $rs->exec()->fetch();
dump($result);