美工统筹SEO,为企业电子商务营销助力!
yii完成级联下拉菜单的体例
一佰互联网站建造(www.taishanly.com) 宣布日期 2020-04-29 09:01:07 阅读数: 91
本文详细报告了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; }