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

前端技术 2023/09/01 PHP

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

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

<?php
 echo $form->dropDownList($model, \'src_type_id\', OrderSrc::options(), array(
 <span style=\"white-space:pre\"> </span>\'id\' => \'task-order-src-id\',
 ));
 echo $form->dropDownList($model, \'src_shop_id\', array(\'\'=>\'全部\'), array(
 <span style=\"white-space:pre\"> </span>\'id\' => \'task-shop-id\',
 ))
?>

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

public static function options($hasShop = true) {
 $model = new self();
 if($hasShop) $model->hasShop();
 $models = $model->findAll();
 $array = array(\'\'=>\'全部\');
 foreach($models as $model) {
 $array[$model->src_id] = $model->src_name;
 }
 return $array;
}

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

<script type=\'text/javascript\'>
$().ready(function(e) {
 $(\'#task-order-src-id\').change(function(e) {
 refreshShops();
 });
 refreshShops();
 function refreshShops() {
 $.get(\'<?php echo $this->createUrl(\'getShops\')?>\', {
  \'srcId\': $(\'#task-order-src-id\').val()
 }, function(html_content) {
  $(\'#task-shop-id\')
  .html(html_content)
  .find(\'option[value=<?php echo $model->src_shop_id?>]\')
   .attr(\'selected\', \'selected\');
 });
 }
});
</script>

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

Controller中的actionGetShops方法如下:

public function actionGetShops() {
 $srcId = $_GET[\'srcId\'];
 $array = ThirdpartInterfaceConfig::options($srcId);
 $htmlContent = \"<option value=\'\'>全部</options>\";
 foreach($array as $k=>$v) {
 $htmlContent .= \"<option value=\'{$k}\'>{$v}</option>\";
 }
 echo $htmlContent;
}

本文地址:https://www.stayed.cn/item/2937

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。