Yii2實(shí)現(xiàn)ActiveForm ajax提交
做項(xiàng)目時(shí)總會(huì)碰到ajax提交的功能,特別是在做后臺(tái)提交時(shí),一般都會(huì)用模型自動(dòng)生成,這個(gè)功能的使用會(huì)比較頻繁,其實(shí)只要了解了流程,操作還是挺簡(jiǎn)單的,使用起來(lái)也方便。
表單部分
<?php $form = ActiveForm::begin([ 'action' => ['save'], //提交地址(*可省略*) 'method'=>'post', //提交方法(*可省略默認(rèn)POST*) 'id' => 'form-save', //設(shè)置ID屬性 'options' => [ 'class' => 'form-horizontal', //設(shè)置class屬性 ], 'enableAjaxValidation' => true, 'validationUrl' => 'validate-view', ]); ?> <?php echo $form->field($model,'company_name', ['inputOptions' => ['placeholder'=>'請(qǐng)輸入商家名稱','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, 必須設(shè)置,告訴表單用ajax提交
控制器(controller)部分
控制器分兩部分,一部分是效驗(yàn)表單的正確性,另外一部分是保存
1、效驗(yàn)部分
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); //返回錯(cuò)誤的表單信息 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('系統(tǒng)錯(cuò)誤'); return false; } }); return false; }); });
特別注意本人用的是Yii2 adminlte框架后臺(tái),具體操作過(guò)程試項(xiàng)目而定,基本操作過(guò)程都一樣。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Zend Framework實(shí)現(xiàn)多文件上傳功能實(shí)例
這篇文章主要介紹了Zend Framework實(shí)現(xiàn)多文件上傳功能的方法,較為詳細(xì)的分析說(shuō)明了Zend Framework實(shí)現(xiàn)多文件上傳的具體步驟與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-03-03phpstudy本地環(huán)境搭建超詳細(xì)圖文教程
這篇文章主要給大家介紹了關(guān)于phpstudy本地環(huán)境搭建超詳細(xì)圖文教程的相關(guān)資料,phpStudy是集安全、高效、功能于一體且完全免費(fèi)的一鍵服務(wù)器環(huán)境搭建軟件,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-07-07thinkphp,onethink和thinkox中驗(yàn)證碼不顯示的解決方法分析
這篇文章主要介紹了thinkphp,onethink和thinkox中驗(yàn)證碼不顯示的解決方法,簡(jiǎn)單分析了thinkPHP驗(yàn)證碼不顯示的原因與相應(yīng)的解決方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06檢測(cè)codeigniter腳本消耗內(nèi)存情況的方法
這篇文章主要介紹了檢測(cè)codeigniter腳本消耗內(nèi)存情況的方法,實(shí)例分析了codeigniter中memory_usage方法及{ memory_usage}偽變量的使用技巧,需要的朋友可以參考下2015-03-03使用array_map簡(jiǎn)單搞定PHP刪除文件、刪除目錄
這篇文章主要介紹了使用array_map簡(jiǎn)單搞定PHP刪除文件、刪除目錄的相關(guān)資料,需要的朋友可以參考下2014-10-10PHP OPP機(jī)制和模式簡(jiǎn)介(抽象類、接口和契約式編程)
本文將介紹抽象類、接口和一種稱為契約式編程的技術(shù)。使用這些OPP機(jī)制,所編寫(xiě)的代碼就不限于只能計(jì)算或者輸出內(nèi)容了。這些機(jī)制能夠在概念層次上定義類之間交互作用的規(guī)則,也為應(yīng)用程序的擴(kuò)展和定制提供了基礎(chǔ)。2014-06-06Laravel事件系統(tǒng)實(shí)現(xiàn)瀏覽量的統(tǒng)計(jì)
Laravel的事件系統(tǒng)提供了一種簡(jiǎn)單而強(qiáng)大的方式來(lái)實(shí)現(xiàn)瀏覽量的統(tǒng)計(jì),通過(guò)創(chuàng)建瀏覽事件和事件監(jiān)聽(tīng)器,以及在合適的地方觸發(fā)事件,我們可以輕松地實(shí)現(xiàn)網(wǎng)頁(yè)瀏覽量的統(tǒng)計(jì)功能,本文將介紹如何使用Laravel的事件系統(tǒng)來(lái)實(shí)現(xiàn)瀏覽量的統(tǒng)計(jì)2024-03-03