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中,文件上传
Dec 06 PHP
php代码中使用换行及(\n或\r\n和br)的应用
Feb 02 PHP
解析isset与is_null的区别
Aug 09 PHP
php注册登录系统简化版
Dec 28 PHP
PHP-FPM实现性能优化
Mar 31 PHP
ThinkPHP实现附件上传功能
Apr 27 PHP
创建无限极分类树型结构的简单方法
Jun 20 PHP
使用PHP+MySql+Ajax+jQuery实现省市区三级联动功能示例
Sep 15 PHP
PHP封装的XML简单操作类完整实例
Nov 13 PHP
PHP调用微博接口实现微博登录的方法示例
Sep 22 PHP
PHP copy函数使用案例代码解析
Sep 01 PHP
Linux系统下安装PHP7.3版本
Jun 26 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文件
2007/01/04 PHP
php中防止伪造跨站请求的小招式
2011/09/02 PHP
浅谈javascript 面向对象编程
2009/10/28 Javascript
Javascript 面向对象(三)接口代码
2012/05/23 Javascript
20行代码实现的一个CSS覆盖率测试脚本
2013/07/07 Javascript
Jquery的hover方法让鼠标经过li时背景变色
2013/09/06 Javascript
JavaScript中诡异的delete操作符
2015/03/12 Javascript
jQuery实现复选框批量选择与反选的方法
2015/06/17 Javascript
javascript禁止访客复制网页内容的实现代码
2015/08/05 Javascript
js实现当前输入框高亮显示的方法
2015/08/19 Javascript
jQuery选择器及jquery案例详解(必看)
2016/05/20 Javascript
Bootstrap Navbar Component实现响应式导航
2016/10/08 Javascript
vue2.0父子组件及非父子组件之间的通信方法
2017/01/21 Javascript
javascript 显示全局变量与隐式全局变量的区别
2017/02/09 Javascript
Vue表单验证插件的制作过程
2017/04/01 Javascript
JS利用正则表达式实现简单的密码强弱判断实例
2017/06/16 Javascript
详解Angular.js中$http拦截器的介绍及使用
2017/07/04 Javascript
简单实现jQuery上传图片显示预览功能
2020/06/29 jQuery
解决在vue项目中,发版之后,背景图片报错,路径不对的问题
2018/03/06 Javascript
mustache.js实现首页元件动态渲染的示例代码
2020/12/28 Javascript
[02:43]DOTA2亚洲邀请赛场馆攻略——带你走进东方体育中心
2018/03/19 DOTA
python列表操作之extend和append的区别实例分析
2015/07/28 Python
Python进度条实时显示处理进度的示例代码
2018/01/30 Python
Python爬虫信息输入及页面的切换方法
2018/05/11 Python
Python使用pymongo库操作MongoDB数据库的方法实例
2019/02/22 Python
python 读取数据库并绘图的实例
2019/12/03 Python
将matplotlib绘图嵌入pyqt的方法示例
2020/01/08 Python
利用jupyter网页版本进行python函数查询方式
2020/04/14 Python
Pyinstaller 打包发布经验总结
2020/06/02 Python
时尚孕妇装:Ingrid & Isabel
2019/05/08 全球购物
英国领先的在线高尔夫商店:Scottsdale Golf
2019/08/26 全球购物
公司领导推荐信
2013/11/12 职场文书
颁奖晚会主持词
2014/03/25 职场文书
学生党员一帮一活动总结
2014/07/08 职场文书
道德与公民自我评价
2015/03/09 职场文书
禁毒心得体会范文
2016/01/15 职场文书