承接 unique/yii2-model-image 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

unique/yii2-model-image

Composer 安装命令:

composer require unique/yii2-model-image

包简介

Allows to easily attach an image to a model in Yii2 framework

README 文档

README

A behavior for Yii2 Framework model class, that allows to easily attach an image, when saving a model.

Installation

The preferred way to install this extension is through composer.

Either run

composer require unique/yii2-model-image

or add

"unique/yii2-model-image": "@dev"

to the require section of your composer.json file.

To create DB tables run migration file:

./yii migrate --migrationPath="vendor/unique/yii2-model-image/src/migrations"

Usage

In order to use the behavior, you first need to load the module. Module can only be loaded once. Add the following to your config file:

<?php
    [
        'bootstrap' => [ 
            // ...,
            'images' 
        ],
        // ...
        'modules' => [
            'images' => [
                'class' => \unique\yii2modelimage\ModelImageModule::class,
                
                // Defines an alias friendly path, where to store all the images
                'images_path' => '@app/www/images',
                
                // specify an Image class to use for generating images
                // should either extend the default class or implement methods needed
                'image_class' => \unique\yii2modelimage\models\Image::class,
                
                // Should list ImageDimensions for all image version groups, i.e.:    
                'group_versions' => [
                    // 'user_profile_photo' => [
                    //     'thumb_small' => ( new ImageDimensions( 'thumb_small', null, 80 ) )->asResized()->setQuality( 80 ),
                    //     'thumb_large' => ( new ImageDimensions( 'thumb_large', null, 800 ) )->asResized()->setQuality( 80 ),
                    // ],
                ],
            ],
            // ...
        ]   
    ]
?>

Then your model can implement a behavior like so:

    class Profile extends \yii\db\ActiveRecord {
    
        // ...
        public $profile_photo;
    
        public function behaviors() {

            return array_merge( parent::behaviors(), [
                'image' => [
                    'class' => ImageBehavior::class,
                    'uploaded_file_attribute' => 'profile_photo',
                    'image_attribute' => 'profile_photo_id',
                    'group' => 'user_profile_photo',
                ]
            ] );
        }
        
        public function rules() {
        
            return [
                // ...
                [ [ 'profile_photo' ], 'file', 'extensions' => 'jpg' ],
            ];
        }
    }

Now, when saving Profile model, an uploaded image will be saved automatically, also generating the two associated versions of the image called thumb_small and thumb_large. If an error occurs, while saving the image, Profile::save() will return false and an error will be set on the Profile::$profile_photo attribute.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-02-09

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固