加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

yii2中dropDownList实现二级和三级联动写法

发布时间:2020-12-12 22:06:38 所属栏目:PHP教程 来源:网络整理
导读:整理文档,搜刮出一个yii2中dropDownList实现二级和三级联动写法的代码,稍微整理精简一下做下分享。 视图页面: ['index'],'method' => 'get',]); ?> field($model,'cocate_id')->dropDownList(Helper::courseCateMap(),['prompt' => yii::t('backend','Ple

整理文档,搜刮出一个yii2中dropDownList实现二级和三级联动写法的代码,稍微整理精简一下做下分享。

视图页面:

['index'],'method' => 'get',]); ?> field($model,'cocate_id')->dropDownList(Helper::courseCateMap(),['prompt' => yii::t('backend','Please select course cate')]) ?> field($model,'course_id')->dropDownList(Helper::courseMap($model->cocate_id),'Please select first course cate')])?> field($model,'person_id')->dropDownList(Helper::personMap(1,$model->cocate_id),'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').'");//二级显示目录标签
$("#classsearch-person_id").html("<option value="">'.yii::t('backend','Please select person').'");//三级显示目录标签(如果 你只需要二级 三级的可以直接删除掉)
if (cocateId > 0) {
getCourse(cocateId);//查询二级目录的方法
getPerson(cocateId);//查询三级目录的方法(如果 你只需要二级 三级的可以直接删除掉)
}
});

function getCourse(cocateId){
var href = "'.Url::to(['/ajax/option']).'";//请求的地址
$.ajax({
"type" : "GET","url" : href,"data" : {cocateId : cocateId,type : "course"},//所需参数和类型
success : function(d) {
$("#classsearch-course_id").append(d);//返回值输出
}
});
}

function getPerson(cocateId){
var href = "'.Url::to(['/ajax/option']).'";//同上
$.ajax({
"type" : "GET",type : "person"},//所需参数和类型
success : function(d) {
$("#classsearch-person_id").append(d);//同上
}
});
}

';
$this->registerJs($js);
?>

php代码:

这个是ajax自己声明的控制器:

namespace backendcontrollers;
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 .= "";
}
echo $_tmp;
}

Helper.php 封装好的类文件 可以单独建立文件 在配置中引用 :

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;

}
}
?>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读