zoukankan      html  css  js  c++  java
  • yii实现级联下拉菜单

    在模版中

    <?php
    	echo $form->dropDownList($model, 'src_type_id', OrderSrc::options(), array(
    		'id' => 'task-order-src-id',
    	));
    	echo $form->dropDownList($model, 'src_shop_id', array(''=>'全部'), array(
    		'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;
    	}
    

    然后在模版页面中增加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方法),任何追加到第二个下拉菜单中。

    	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;
    	}




    Meet so Meet. C plusplus I-PLUS....
  • 相关阅读:
    List数组细解
    iOS之缓存
    Java_String的操作
    weak的理解
    Swift_单利
    Java 抽象类和接口
    Java 继承中的问题
    java 成员变量与局部变量
    纪中第十九天
    cin快读
  • 原文地址:https://www.cnblogs.com/iplus/p/4489986.html
Copyright © 2011-2022 走看看