Yii2實現(xiàn)ajax上傳圖片插件用法

字號:


    本文實例講述了Yii2實現(xiàn)ajax上傳圖片插件用法。分享給大家供大家參考,具體如下:
    這里需要先下載 mdmsoft/yii2-upload-file.插件。
    代碼如下:
    public function actionCreate()
    {
      $model = new DynamicModel([
        'nama', 'file_id'
        ]);
      // behavior untuk upload file
      $model->attachBehavior('upload', [
        'class' => 'mdm\upload\UploadBehavior',
        'attribute' => 'file',
        'savedAttribute' => 'file_id' // coresponding with $model->file_id
      ]);
      // rule untuk model
      $model->addRule('nama', 'string')
        ->addRule('file', 'file', ['extensions' => 'jpg']);
      if ($model->load(Yii::$app->request->post()) && $model->validate()) {
        if ($model->saveUploadedFile() !== false) {
          Yii::$app->session->setFlash('success', 'Upload Sukses');
        }
      }
      return $this->render('upload',['model' => $model]);
    }
    Then in view upload.php
    <?php
    use yii\helpers\Html;
    use yii\widgets\ActiveForm;
    /* @var $this yii\web\View */
    ?>
    <div>
      <?php
      $form = ActiveForm::begin([
          'options' => [ 'enctype' => 'multipart/form-data']
      ]);
      ?>
      <?= $form->field($model, 'nama'); ?>
      <?= $form->field($model, 'file')->fileInput(); ?>
      <?php if ($model->file_id): ?>
        <div>
          <?= Html::img(['/file', 'id' => $model->file_id]) ?>
        </div>
      <?php endif; ?>
      <div>
        <?= Html::submitButton('Submit', ['class' => 'btn btn-primary']) ?>
      </div>
      <?php ActiveForm::end(); ?>
    </div>
    希望本文所述對大家基于Yii框架的PHP程序設計有所幫助。