您当前的位置: 首页 > 网站编程 > PHP教程 > 下拉列表多级联动dropDownList示例代码

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

作者:不详 来源:网络 发布时间: 2014-08-19 14:21 点击:
视图: 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()-createU

下拉列表多级联动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示例代码"由远航站长收集整理而来,仅供大家学习与参考使用。更多网站制作教程尽在远航站长站。
顶一下
(0)
0%
踩一下
(0)
0%
[点击 次] [返回上一页] [打印]
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 密码: 验证码:
关于本站 - 联系我们 - 广告合作 - 网站声明 - 友情连接- 网站地图 - 站点地图 - 返回顶部
Copyright © 2007-2013 www.yhzhan.com(远航站长). All Rights Reserved .
远航站长:为中小站长提供最佳的学习与交流平台,提供网页制作与网站编程等各类网站制作教程.
官方QQ:445490277 网站群:26680406 网站备案号:豫ICP备07500620号-4