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


Posted in PHP onApril 26, 2017

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

视图页面:

<?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>");//二级显示目录标签
  $("#classsearch-person_id").html("<option value=\"\">'.yii::t('backend', 'Please select person').'</option>");//三级显示目录标签(如果 你只需要二级 三级的可以直接删除掉)
  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",
    "url"  : href,
    "data" : {cocateId : cocateId,type : "person"},//所需参数和类型
    success : function(d) {
      $("#classsearch-person_id").append(d);//同上
    }
  });
}
    
  
';
$this->registerJs($js);
?>

php代码:

这个是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 封装好的类文件 可以单独建立文件 在配置中引用 :

<?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;
  }
  }
  ?>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
PHP 5.0对象模型深度探索之绑定
Sep 05 PHP
用php+javascript实现二级级联菜单的制作
May 06 PHP
破解图片防盗链的代码(asp/php)测试通过
Jul 02 PHP
在MongoDB中模拟Auto Increment的php代码
Mar 06 PHP
PHP中读写文件实现代码
Oct 20 PHP
关于js和php对url编码的处理方法
Mar 04 PHP
PHP中文乱码解决方案
Mar 05 PHP
[原创]php简单防盗链验证实现方法
Jul 09 PHP
php curl 模拟登录并获取数据实例详解
Dec 22 PHP
php读取本地json文件的实例
Mar 07 PHP
PHP实现数组和对象的相互转换操作示例
Mar 20 PHP
PHP获取远程http或ftp文件的md5值的方法
Apr 15 PHP
MAC下通过改apache配置文件切换php多版本的方法
Apr 26 #PHP
PHP编程计算日期间隔天数的方法
Apr 26 #PHP
浅谈PHP中类和对象的相关函数
Apr 26 #PHP
详解PHP防止盗链防止迅雷下载的方法
Apr 26 #PHP
php数组实现根据某个键值将相同键值合并生成新二维数组的方法
Apr 26 #PHP
ThinkPHP中create()方法自动验证实例
Apr 26 #PHP
PHP使用imagick扩展实现合并图像的方法
Apr 25 #PHP
You might like
咖啡与牛奶
2021/03/03 冲泡冲煮
PHP伪静态Rewrite设置之APACHE篇
2014/07/30 PHP
php写一个函数,实现扫描并打印出自定目录下(含子目录)所有jpg文件名
2017/05/26 PHP
PHP机器学习库php-ml的简单测试和使用方法
2017/07/14 PHP
用jquery中插件dialog实现弹框效果实例代码
2013/11/15 Javascript
网页中表单按回车就自动提交的问题的解决方案
2014/11/03 Javascript
AngularJS 中的事件详解
2016/07/28 Javascript
BootStrap按钮标签及基本样式
2016/11/23 Javascript
实例解析jQuery工具函数
2016/12/01 Javascript
js实现城市级联菜单的2种方法
2017/06/23 Javascript
Vue 实现前端权限控制的示例代码
2019/07/09 Javascript
弱类型语言javascript中 a,b 的运算实例小结
2019/08/07 Javascript
你不可不知的Vue.js列表渲染详解
2019/10/01 Javascript
Vue程序化的事件监听器(实例方案详解)
2020/01/07 Javascript
[02:36]DOTA2混沌骑士 英雄基础教程
2013/11/26 DOTA
[01:54]TI珍贵瞬间系列(三):翻盘
2020/08/28 DOTA
浅谈Python类里的__init__方法函数,Python类的构造函数
2016/12/10 Python
Python实现的多线程同步与互斥锁功能示例
2017/11/30 Python
解决python打不开文件(文件不存在)的问题
2019/02/18 Python
Python3列表内置方法大全及示例代码小结
2019/05/10 Python
基于树莓派的语音对话机器人
2019/06/17 Python
python中使用you-get库批量在线下载bilibili视频的教程
2020/03/10 Python
python3 使用openpyxl将mysql数据写入xlsx的操作
2020/05/15 Python
Python 解析xml文件的示例
2020/09/29 Python
HelloFresh奥地利:立即订购烹饪盒
2019/02/22 全球购物
J2EE相关知识面试题
2013/08/26 面试题
销售实习自我鉴定
2013/12/07 职场文书
我的网上商城创业计划书
2013/12/26 职场文书
党员培训思想汇报
2014/01/07 职场文书
岗位职责风险点
2014/03/12 职场文书
年会主持词结束语
2014/03/27 职场文书
保护环境演讲稿
2014/05/10 职场文书
公司委托书怎么写
2014/08/02 职场文书
大学生村官工作总结2015
2015/04/09 职场文书
表彰大会新闻稿
2015/07/17 职场文书
python办公自动化之excel的操作
2021/05/23 Python