下拉列表多级联动dropDownList示例代码

  视图:

  cdnauto/views/config/index.php

  

复制代码 代码如下:

  echo CHtml::dropDownList('node', '', CHtml::listData(Node::model()->findAll(),'name','name'),array('empty'=>'--请选择节点--',

  'id' => 'node',

  'ajax'=>array(

  'type'=>'POST',

  'url'=>Yii::app()->createUrl('cdnauto/config/getNodeServersByNodeName'),

  'update'=>'#servers',

  'data'=>array('node_name'=>'js:$("#node").val()'),

  )

  )

  );

  echo "        ";

  echo CHtml::dropDownList('servers', '', array('--请选择服务器--'));

  控制器:

  cdnauto/controllers/ConfigController.php

  

复制代码 代码如下:

  public function actionGetNodeServersByNodeName(){

  // if(!Yii::app()->request->isAjaxRequest)

  // throw new CHttpException(404);

  $node_name = $_POST['node_name'];

  $nodeid = Node::model()->getNodeId($_POST['node_name']); //通过节点名称获取该节点ID

  $server = GossServer::model()->getServerByNodeid($nodeid); //通过节点ID获取服务器信息

  //$server 为array类型,形如 $server = array(array('name'=>'name1'),array('name'=>'name2'));所以需要两次foreach

  if(isset($server)){

  foreach ($server as $k=>$v){

  foreach($v as $kk => $vv){

  echo CHtml::tag('option', array('value'=>$kk), CHtml::encode($vv), true);

  }

  }

  }else{

  echo CHtml::tag('option', array('value'=>''), 'servers', true);

  }

  }

  模型:

  GossServer.php

  

复制代码 代码如下:

  /**

  * 通过节点ID获取该节点下所有的服务器名称

  * @author ysdaniel

  */

  public static function getServerByNodeid($nodeid)

  {

  $sql = "SELECT name FROM OSS_Server WHERE nodeid = '{$nodeid}' ";

  ///$sql = "SELECT name,nodeid FROM OSS_Server WHERE nodeid = '{$nodeid}' "; //both ok

  $cmd = Yii::app()->db->createCommand($sql);

  $ret = $cmd->queryAll();

  if (!$ret){

  throw new Exception("找不到这个节点对应的服务器");

  }

  return $ret;

  }

  Node.php

  

复制代码 代码如下:

  /**

  * 通过nodename获取nodeid名

  * @author

  */

  public static function getNodeId($name)

  {

  $sql = "SELECT id FROM OSS_Node WHERE name = '{$name}'";

  $cmd = Yii::app()->db->createCommand($sql);

  $ret = $cmd->queryAll();

  if (!$ret){

  return null;

  //throw new Exception("找不到Node{$name}");

  }

  return $ret[0]['id'];

  }

  其它:

  数据表结构

  效果:

  没有选择节点前:

下拉列表多级联动dropDownList示例代码

  细节有空再补上了。