dvizh/yii2-field 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

dvizh/yii2-field

Composer 安装命令:

composer require dvizh/yii2-field

包简介

yii2-field add fields to your model

README 文档

README

С помощью данного модуля можно добавить поля для какой-то модели через веб-интерфейс и потом производить выборки по значению.

Типы полей на данный момент:

  • Text
  • Numeric
  • Date
  • Textarea
  • Select
  • Radio
  • Checkbox
  • Image (в разработке)

Для select, radio, checkbox можно заранее задавать в настройках варианты.

Установка

Выполнить команду

php composer require dvizh/yii2-field "@dev"

Или добавить в composer.json

"dvizh/yii2-field": "@dev",

И выполнить

php composer update

Далее, мигрируем базу:

php yii migrate --migrationPath=vendor/dvizh/yii2-field/src/migrations

Подключение и настройка

В конфигурационный файл приложения добавить модуль field, настроив его

    'modules' => [
        //...
        'field' => [
            'class' => 'dvizh\field\Module',
            'relationModels' => [
                'common\models\User' => 'Пользователи',
                'dvizh\shop\models\Product' => 'Продукты',
            ],
            'adminRoles' => ['administrator'],
        ],
        //...
    ]
  • relationModels - перечень моделей, к которым можно прикрепить поля

Все доступные CRUD для управления полями: ?r=field/defailt/index

Для модели, с которой будут работать поля, добавить поведение:

    function behaviors() {
        return [
            'field' => [
                'class' => 'dvizh\field\behaviors\AttachFields',
            ],
        ];
    }

Чтобы иметь возможность также фильтровать результаты Find, подменяем Query в модели:

    public static function Find()
    {
        $return = new ProductQuery(get_called_class());
        return $return;
    }

В ProductQuery должно быть это поведение:

    function behaviors()
    {
       return [
           'field' => [
               'class' => 'dvizh\field\behaviors\Filtered',
           ],
       ];
    }

Использование

Значение поля для модели вызывается через getField(), которому передается код поля.

echo $model->getField('field_name');

Выбрать все записи по значению значению поля:

$productsFind = Product::find()->field('power', 100)->all(); //Все записи с power=100
$productsFind = Product::find()->field('power', 100, '>')->all(); //Все записи с power>100
$productsFind = Product::find()->field('power', 100, '<')->all(); //Все записи с power<100

Виджеты

Блок выбора значений для для полей модели $model (вставлять в админке, рядом с формой редактирования):

<?=\dvizh\field\widgets\Choice::widget(['model' => $model]);?>

Вывести все поля модели со значениями:

<?=dvizh\field\widgets\Show::widget(['model' => $model]);?>		

统计信息

  • 总下载量: 1.74k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 11
  • 点击次数: 0
  • 依赖项目数: 2
  • 推荐数: 0

GitHub 信息

  • Stars: 10
  • Watchers: 2
  • Forks: 4
  • 开发语言: PHP

其他信息

  • 授权协议: Apache-2.0
  • 更新时间: 2017-04-21

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固