yii2中dropDownList實(shí)現(xiàn)二級和三級聯(lián)動寫法
更新時(shí)間:2017年04月26日 10:34:57 作者:憐晚情之淚
本篇文章主要介紹了yii2中dropDownList實(shí)現(xiàn)二級和三級聯(lián)動寫法 ,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
整理文檔,搜刮出一個(gè)yii2中dropDownList實(shí)現(xiàn)二級和三級聯(lián)動寫法的代碼,稍微整理精簡一下做下分享。
視圖頁面:
<?php $form = ActiveForm::begin([
'action' => ['index'],
'method' => 'get',
]); ?>
<!--一級目錄--> <?= $form->field($model, 'cocate_id')->dropDownList(Helper::courseCateMap(), ['prompt' => yii::t('backend', 'Please select course cate')]) ?>
<!--二級目錄--><?= $form->field($model, 'course_id')->dropDownList(Helper::courseMap($model->cocate_id), ['prompt' => yii::t('backend', 'Please select first course cate')])?>
<!--三級目錄--><?= $form->field($model, 'person_id')->dropDownList(Helper::personMap(1, $model->cocate_id), ['prompt' => yii::t('backend', 'Please select person')]) ?>
<?php ActiveForm::end(); ?>
頁面嵌套js
<?php
$js = '
//分類
$("#classsearch-cocate_id").change(function() {
var cocateId = $(this).val();//獲取一級目錄的值
$("#classsearch-course_id").html("<option value=\"\">'.yii::t('backend', 'Please select course').'</option>");//二級顯示目錄標(biāo)簽
$("#classsearch-person_id").html("<option value=\"\">'.yii::t('backend', 'Please select person').'</option>");//三級顯示目錄標(biāo)簽(如果 你只需要二級 三級的可以直接刪除掉)
if (cocateId > 0) {
getCourse(cocateId);//查詢二級目錄的方法
getPerson(cocateId);//查詢?nèi)壞夸浀姆椒ǎㄈ绻?你只需要二級 三級的可以直接刪除掉)
}
});
function getCourse(cocateId){
var href = "'.Url::to(['/ajax/option']).'";//請求的地址
$.ajax({
"type" : "GET",
"url" : href,
"data" : {cocateId : cocateId,type : "course"},//所需參數(shù)和類型
success : function(d) {
$("#classsearch-course_id").append(d);//返回值輸出
}
});
}
function getPerson(cocateId){
var href = "'.Url::to(['/ajax/option']).'";//同上
$.ajax({
"type" : "GET",
"url" : href,
"data" : {cocateId : cocateId,type : "person"},//所需參數(shù)和類型
success : function(d) {
$("#classsearch-person_id").append(d);//同上
}
});
}
';
$this->registerJs($js);
?>
php代碼:
這個(gè)是ajax自己聲明的控制器:
<?php
namespace backend\controllers;
class AjaxController extends BaseController
{
public function actionOption($cocateId, $type)
{
switch ($type) {
case 'course':
$_data = Helper::courseMap($cocateId);
break;
case 'person':
$_data = Helper::personMap(1, $cocateId);
break;
case 'class':
$_data = Helper::classMap($cocateId);
break;
}
$_tmp = '';
foreach ($_data as $key => $val) {
$_tmp .= "<option value='" . $key . "'>{$val}</option>";
}
echo $_tmp;
}
Helper.php 封裝好的類文件 可以單獨(dú)建立文件 在配置中引用 :
<?php
namespace backend\components;//繼承的空間路徑
class Helper//聲明類
{
//聲明查詢的方法 一級
public static function courseCateMap()
{
$_data = CourseCate::find()->select('cocate_id,cocate_name')->all();
$_data = ArrayHelper::map(array_merge($_data), 'cocate_id', 'cocate_name');
return $_data;
}
//聲明查詢的方法 二級
public static function courseMap($cocateId)
{
$condition['cocate_id'] = $cocateId;
$_data = Course::find()->select('course_id,course_name')->where($condition)->all();
$_data = ArrayHelper::map(array_merge($_data), 'course_id', 'course_name');
return $_data;
}
//聲明查詢的方法 三級
public static function personMap($percateId, $cocateId = 0)
{
$shopId = Yii::$app->user->identity->shop_id;
$condition = [];
if ($shopId)
{
$condition['shop_id'] = $shopId;
}
if ($percateId)
{
$condition['percate_id'] = $percateId;
}
if ($cocateId)
{
$condition['cocate_ids'] = intval($cocateId);
}
$_data = Person::find()->select('person_id,person_name')->where($condition)->all();
$_data = ArrayHelper::map(array_merge($_data), 'person_id', 'person_name');
return $_data;
}
}
?>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Laravel 5.2 文檔 數(shù)據(jù)庫 —— 起步介紹
今天小編就為大家分享一篇Laravel 5.2 文檔 數(shù)據(jù)庫 —— 起步介紹,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10
Yii框架 session 數(shù)據(jù)庫存儲操作方法示例
這篇文章主要介紹了Yii框架 session 數(shù)據(jù)庫存儲操作方法,結(jié)合實(shí)例形式分析了使用Yii框架session組件配置與數(shù)據(jù)庫存儲相關(guān)操作技巧,需要的朋友可以參考下2019-11-11
Laravel 5使用Laravel Excel實(shí)現(xiàn)Excel/CSV文件導(dǎo)入導(dǎo)出的功能詳解
這篇文章主要給大家介紹了關(guān)于在Laravel 5中如何使用Laravel Excel實(shí)現(xiàn)Excel/CSV文件導(dǎo)入導(dǎo)出功能的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下。2017-10-10

