carono/yii2-attribute-behavior 问题修复 & 功能扩展

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

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

carono/yii2-attribute-behavior

最新稳定版本:1.0.1

Composer 安装命令:

composer require carono/yii2-attribute-behavior

包简介

Yii2 behavior that triggers custom events when specific model attributes change. Provides flexible attribute-level event handling for ActiveRecord models with onChange{Attribute} and onInsert{Attribute} method patterns.

README 文档

README

Here’s a README in English for your Yii2 behavior code:

Model Attribute Event Behavior for Yii2

A behavior for Yii2 ActiveRecord that triggers custom methods when specific model attributes are changed. Useful for handling attribute-specific logic after insert/update operations.

Installation

Place the ModelAttributeEventBehaviour class in your project (e.g., under components/behaviors). Ensure the namespace matches your project structure.

Usage

  1. Extend the Behavior: Create a new class inheriting from ModelAttributeEventBehaviour.
  2. Attach to Model: Attach the behavior to your ActiveRecord model.
  3. Define Handlers: Implement methods in the format onChange{AttributeName} or onInsert{AttributeName} to handle attribute changes.

Example

Step 1: Create a Custom Behavior Class

namespace app\components\behaviors;

class MyEventBehavior extends \carono\yii2\behaviors\ModelAttributeEventBehaviour
{
    public function onChangeStatusId($event, $insert, $model, $value, $oldValue, $changedAttributes)
    {
        // Triggered when `status_id` changes
        if (!$insert && $oldValue != $value) {
            // Custom logic here (e.g., send notification, log change)
        }
    }

    public function onInsertEmail($event, $insert, $model, $value, $oldValue, $changedAttributes)
    {
        // Triggered when `email` is set during model creation
        if ($insert) {
            // Custom logic for new email
        }
    }
}

Step 2: Attach to Your Model

namespace app\models;

use yii\db\ActiveRecord;
use app\components\behaviors\MyEventBehavior;

class User extends ActiveRecord
{
    public function behaviors()
    {
        return [
            MyEventBehavior::class,
        ];
    }
}

Method Parameters

Handler methods receive the following arguments:

  • $event: The AfterSaveEvent object.
  • $insert: Boolean indicating if the model was just inserted.
  • $model: The ActiveRecord model instance.
  • $value: New value of the attribute.
  • $oldValue: Old value of the attribute.
  • $changedAttributes: Array of all changed attributes and their old values (as in $event->changedAttributes).

Events

  • After Insert: Triggers methods prefixed with onInsert (e.g., onInsertEmail for the email attribute).
  • After Update: Triggers methods prefixed with onChange (e.g., onChangeStatusId for the status_id attribute).

Important Notes

  • The $changedAttributes array contains the old values of changed attributes.
  • Handlers are only triggered if the attribute value actually changes (as detected by Yii2’s dirty attributes).
  • The behavior automatically binds to the EVENT_AFTER_INSERT and EVENT_AFTER_UPDATE events.

License

MIT

统计信息

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

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-09-15

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固