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 相关文章推荐
将OICQ数据转成MYSQL数据
Oct 09 PHP
php5数字型字符串加解密代码
Apr 24 PHP
php 无限级缓存的类的扩展
Mar 16 PHP
php visitFile()遍历指定文件夹函数
Aug 21 PHP
php 获取百度的热词数据的代码
Feb 18 PHP
php数组去重的函数代码
Feb 03 PHP
深入理解:单一入口、MVC、ORM、CURD、ActiveRecord概念
Jun 06 PHP
php json_encode值中大括号与花括号区别
Sep 30 PHP
PHP连接MySQL数据的操作要点
Mar 20 PHP
PHP按指定键值对二维数组进行排序的方法
Dec 22 PHP
PHP flush 函数使用注意事项
Aug 26 PHP
laravel unique验证、确认密码confirmed验证以及密码修改验证的方法
Oct 16 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
php+mysql开源XNA 聚合程序发布 下载
2007/07/13 PHP
php截取字符串并保留完整xml标签的函数代码
2013/02/06 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(一)
2014/06/23 PHP
phpStudy2016 配置多个域名期间遇到的问题小结
2017/10/19 PHP
PHP简单实现欧拉函数Euler功能示例
2017/11/06 PHP
layui数据表格自定义每页条数limit设置
2019/10/26 PHP
javascript encodeURI和encodeURIComponent的比较
2010/04/03 Javascript
jquery实现显示已选用户
2014/07/21 Javascript
JS鼠标拖拽实例分析
2015/11/23 Javascript
javascript瀑布流式图片懒加载实例
2020/06/28 Javascript
js实现手机拍照上传功能
2017/01/17 Javascript
WebStorm ES6 语法支持设置&amp;babel使用及自动编译(详解)
2017/09/08 Javascript
一个有意思的鼠标点击文字特效jquery代码
2017/09/23 jQuery
JS实现的简单表单验证功能示例
2017/10/13 Javascript
vue组件生命周期详解
2017/11/07 Javascript
实例详解带参数的 npm script
2019/05/28 Javascript
微信小程序vant弹窗组件的实现方式
2020/02/21 Javascript
Vue使用v-viewer实现图片预览
2020/10/21 Javascript
python中二维阵列的变换实例
2014/10/09 Python
Python中的hypot()方法使用简介
2015/05/18 Python
Python编程pygal绘图实例之XY线
2017/12/09 Python
详解python函数传参是传值还是传引用
2018/01/16 Python
机器学习之KNN算法原理及Python实现方法详解
2018/07/09 Python
简单瞅瞅Python vars()内置函数的实现
2019/09/27 Python
浅析python,PyCharm,Anaconda三者之间的关系
2019/11/27 Python
python 发送get请求接口详解
2020/11/17 Python
Alexandre Birman美国官网:亚历山大·伯曼
2019/10/30 全球购物
Ibatis如何调用存储过程
2015/05/15 面试题
亿阳信通股份有限公司笔试题(C#)
2016/03/04 面试题
怎样写留学自荐信
2013/11/11 职场文书
护士实习生自我鉴定范文
2013/12/10 职场文书
小学校长先进事迹材料
2014/05/13 职场文书
促销活动总结模板
2014/07/01 职场文书
在宿舍喝酒的检讨书
2014/09/28 职场文书
Mysql外键约束的创建与删除的使用
2022/03/03 MySQL
python标准库ElementTree处理xml
2022/05/20 Python