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

DropDownList控件又称下拉列表框控件, 控件 列表 中的多行数 据 以隐含 的形式表 示 出 来,当用户需要选择所需列表项时,通过点击 “下三角 ”图形 展示 ,用户每次 只能选用一个 数据项。DropDownList控件实际上是列表项 的 容器 ,下拉列表框 用 Items集合表示各项 的内 容。如果在 ASP.NET页面中逐个 的手 动填写 DropDownList控件的列表选项,当列表项很多 的时候会 比较繁琐 ,而且修改 比较麻烦 。 DropDownList控件动态连接到数据库,按指定 条件从数据库 中查询 出列表选项数据,然后绑 定到控件,可以方便快速地显示出多个下拉选 项 。 同时 ,通过修 改数据库 中数据 ,可 以动 态改 变下 拉选项。例如 ,在导 师遴 选系统 中, 研究生导师填写申请信息 的时候 ,需要选 择申 请类型,而且同样的信息在多处页面出现,将 数据库中申请类型表的数据绑定到 DropDownList控件上,能比较好的解决问题。

本文为大家详细介绍下下拉列表多级联动 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.phppublic 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'];

}

其它:

数据表结构

效果:

没有选择节点前:

dcad0dcf3fc6b57ad55733d614881c1a.gif

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值