jQuery基于函數重載實現自定義Alert函數樣式的方法
688
2024-02-23
做項目時總會碰到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提交
控制器(controller)部分
控制器分兩部分,一部分是效驗表單的正確性,另外一部分是保存
1、效驗部分
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']; } }
Ajax提交from表單
$(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框架后臺,具體操作過程試項目而定,基本操作過程都一樣。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持綠夏網。
#免責聲明#
本站[綠夏技術導航]提供的一切軟件、教程和內容信息僅限用于學習和研究目的;不得將上述內容用于商業或者非法用途,否則,一切后果請用戶自負。本站信息來自網絡收集整理,版權爭議與本站無關。您必須在下載后的24個小時之內,從您的電腦或手機中徹底刪除上述內容。如果您喜歡該程序或內容,請支持正版,購買注冊,得到更好的正版服務。我們非常重視版權問題,如有侵權請郵件[admin@lxwl520.com]與我們聯系進行刪除處理。敬請諒解!