做者:PHP學習網 出處:https://www.viphper.com/?p=1240 本文版權歸做者,歡迎轉載,但未經做者贊成必須保留此段聲明,且在文章頁面明顯位置給出原文鏈接,不然保留追究法律責任的權利。php
作項目時總會碰到ajax提交的功能,特別是在作後臺提交時,通常都會用模型自動生成,這個功能的使用會比較頻繁,其實只要瞭解了流程,操做仍是挺簡單的,使用起來也方便。ajax
<?php $form = ActiveForm::begin([ 'action' => ['save'], //提交地址(*可省略*) 'method'=>'post', //提交方法(*可省略默認POST*) 'id' => 'form-save', //設置ID屬性 'options' => [ 'class' => 'form-horizontal', //設置class屬性 ], 'enableAjaxValidation' => true, 'validationUrl' => 'validate-view', ]); ?> <?php echo $form->field($model,'company_name', ['inputOptions' => ['placeholder'=>'請輸入商家名稱','class' => 'form-control'], 'template'=>'<label for="inputCompanyName" class="col-sm-1 control-label"><span class="text-red">*</span> 商家名稱</label><div class="col-md-8">{input}</div><label class="col-sm-3" for="inputError">{error}</label>'])->textInput()?> <?=Html::submitButton('保存',['class'=>'btn btn-primary']); ?> <?php ActiveForm::end(); ?>
其中:'enableAjaxValidation' => true, 必須設置,告訴表單用ajax提交app
控制器分兩部分,一部分是效驗表單的正確性,另一部分是保存框架
1、效驗部分post
public function actionValidateView() { $model = new model(); $request = \Yii::$app->getRequest(); if ($request->isPost && $model->load($request->post())) { \Yii::$app->response->format = Response::FORMAT_JSON; return ActiveForm::validate($model); } }
2、保存部分學習
public function actionSave() { \Yii::$app->response->format = Response::FORMAT_JSON; $params = Yii::$app->request->post(); $model = $this->findModel($params[id]); if (Yii::$app->request->isPost && $model->load($params)) { return ['success' => $model->save()]; } else{ return ['code'=>'error']; } }
$(function(){ $(document).on('beforeSubmit', 'form#form-save', function () { var form = $(this); //返回錯誤的表單信息 if (form.find('.has-error').length) { return false; } //表單提交 $.ajax({ url : form.attr('action'), type : 'post', data : form.serialize(), success: function (response){ if(response.success){ alert('保存成功'); window.location.reload(); } }, error : function (){ alert('系統錯誤'); return false; } }); return false; }); });
特別注意本人用的是Yii2 adminlte框架後臺,具體操做過程試項目而定,基本操做過程都同樣。this