這篇文章主要介紹“yii框架表單模型使用及以數(shù)組形式提交表單數(shù)據(jù)的方法教程”,在日常操作中,相信很多人在yii框架表單模型使用及以數(shù)組形式提交表單數(shù)據(jù)的方法教程問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”yii框架表單模型使用及以數(shù)組形式提交表單數(shù)據(jù)的方法教程”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
十余年的平桂網(wǎng)站建設(shè)經(jīng)驗,針對設(shè)計、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時及時工作處理。成都全網(wǎng)營銷推廣的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整平桂建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計,從而大程度地提升瀏覽體驗。創(chuàng)新互聯(lián)從事“平桂網(wǎng)站設(shè)計”,“平桂網(wǎng)站推廣”以來,每個客戶項目都認(rèn)真落實執(zhí)行。按Yii文檔里的描述,Yii在處理表單的一般過程是:
創(chuàng)建表單對應(yīng)的模型類,設(shè)置字段驗證規(guī)則
創(chuàng)建表單提交對應(yīng)的action,處理提交的內(nèi)容
在視圖中創(chuàng)建表單form
在剛剛的一個小項目里,想使用ajax提交表單信息并驗證保存,又不想用隱藏iframe來做無刷新提交,并且action中能夠用到模型類的校驗方法,就想到使用表單數(shù)組提交的方式,舉個例子:
form代碼:
復(fù)制代碼 代碼如下:
提交后可以直接使用 $_POST['arr'] 來獲取提交的數(shù)據(jù),$_POST['arr'] 為:
復(fù)制代碼 代碼如下:
Array
(
[0] => a
[1] => b
[2] => c
)
同理,如果使用以下form提交:
復(fù)制代碼 代碼如下:
Array
(
[3] => a
[6] => b
[8] => c
)
當(dāng)然也能提交二維數(shù)組:
復(fù)制代碼 代碼如下:
Array
(
[0] => Array
(
[name1] => a
)
[1] => Array
(
[name2] => b
)
[2] => Array
(
[name3] => c
)
)
這里有一個問題,如果不設(shè)置第一個子數(shù)組的key,在生成數(shù)組時會將每個值順序在arr中添加,如果想將信息保存在一個array中,添加一個key值即可,如下:
復(fù)制代碼 代碼如下:
Array
(
[a] => Array
(
[name1] => a1
[value1] => a2
)
[b] => Array
(
[name2] => b1
[value2] => b2
)
)
下面貼一下用ajax提交表單并且用yii表單模型驗證的示例,首先是模型類部分,只有最簡單的校驗方法:
復(fù)制代碼 代碼如下:
class LandingForm extends CFormModel
{
public $landing_title;
public $landing_content;
public $landing_position;
public function rules()
{
return array(
array('landing_title, landing_content', 'required'),
array('landing_position', 'default', 'value'=>''),
);
}
}
發(fā)現(xiàn)個比較有意思的,就是模型類在設(shè)置參數(shù)校驗的方法時,需要對每一個public參數(shù)都設(shè)置規(guī)則,如果有未設(shè)置規(guī)則的參數(shù),在用$_POST中的表單值為模型賦值后,未設(shè)置規(guī)則的參數(shù)值將為空
action中獲取表單提交的參數(shù)并且校驗:
復(fù)制代碼 代碼如下:
$model = new LandingForm;
$model->attributes = $_POST['form'];
if($model->validate()){
$info = $model->attributes;
...
}
最后是前端提交表單部分的代碼,用的jquery:
復(fù)制代碼 代碼如下:
var info = new Object();
info = { 'form[landing_title]': landing_title,
'form[landing_content]': landing_content,
'form[landing_position]': landing_position,
};
var url = "...";
$.post(url, info, function(rst){
...
});
到此,關(guān)于“yii框架表單模型使用及以數(shù)組形式提交表單數(shù)據(jù)的方法教程”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
新聞名稱:yii框架表單模型使用及以數(shù)組形式提交表單數(shù)據(jù)的方法教程-創(chuàng)新互聯(lián)
分享路徑:http://weahome.cn/article/dsgspc.html