1csoft / orm-iblock
ORM D7 для инфоблоков битрикса
1.4.2
2020-11-04 13:51 UTC
Requires
- php: >=7.0.8
- psr/cache: *
- psr/container: *
- psr/link: *
- psr/log: *
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);