当前位置:首页 > CMS教程 > 其它CMS > 列表

yii实现级联下拉菜单的方法

发布:smiling 来源: PHP粉丝网  添加日期:2021-03-28 15:01:19 浏览: 评论:0 

这篇文章主要介绍了yii实现级联下拉菜单的方法,需要的朋友可以参考下

本文详细讲述了yii实现级联下拉菜单的方法,具体步骤如下:

1.模版中加入如下代码:

  1. <?php 
  2.  echo $form->dropDownList($model'src_type_id', OrderSrc::options(), array
  3.  <span style="white-space:pre"> </span>'id' => 'task-order-src-id'
  4.  )); 
  5.  echo $form->dropDownList($model'src_shop_id'array(''=>'全部'), array
  6.  <span style="white-space:pre"> </span>'id' => 'task-shop-id'
  7.  )) 
  8. ?> 

在这段代码中,OrderSrc_options() 这个是先读取一个下拉菜单。调用OrderScr model中的options方法。内容如下

  1. public static function options($hasShop = true) { 
  2.  $model = new self(); 
  3.  if($hasShop$model->hasShop(); 
  4.  $models = $model->findAll(); 
  5.  $array = array(''=>'全部'); 
  6.  foreach($models as $model) { 
  7.  $array[$model->src_id] = $model->src_name; 
  8.  } 
  9.  return $array

2.然后在模版页面中增加JS代码,实现当第一个下拉菜单变化时给第二个下拉菜单进行内容赋值。

  1. <script type='text/javascript'
  2. $().ready(function(e) { 
  3.  $('#task-order-src-id').change(function(e) { 
  4.  refreshShops(); 
  5.  }); 
  6.  refreshShops(); 
  7.  function refreshShops() { 
  8.  $.get('<?php echo $this->createUrl('getShops')?>', { 
  9.   'srcId': $('#task-order-src-id').val() 
  10.  }, function(html_content) { 
  11.   $('#task-shop-id'
  12.   .html(html_content) 
  13.   .find('option[value=<?php echo $model->src_shop_id?>]'
  14.    .attr('selected''selected'); 
  15.  }); 
  16.  } 
  17. }); 
  18. </script> 

在这段JS代码中,实现调取一个程序获取第二个下拉菜单的值(调用Controller中的actionGetShops方法),任何追加到第二个下拉菜单中。

Controller中的actionGetShops方法如下:

  1. public function actionGetShops() { 
  2.  $srcId = $_GET['srcId']; 
  3.  $array = ThirdpartInterfaceConfig::options($srcId); 
  4.  $htmlContent = "<option value=''>全部</options>"
  5.  foreach($array as $k=>$v) { 
  6.  $htmlContent .= "<option value='{$k}'>{$v}</option>"
  7.  } 
  8.  echo $htmlContent

Tags: yii级联下拉菜单

分享到: