下拉列表多級聯(lián)動dropDownList示例代碼
更新時間:2013年06月27日 17:22:04 作者:
本文為大家詳細介紹下下拉列表多級聯(lián)動 dropDownList具體的實現代碼,感興趣的朋友可以參考下哈,至于一些細節(jié)部分后續(xù)再補
視圖:
cdnauto/views/config/index.php
echo CHtml::dropDownList('node', '', CHtml::listData(Node::model()->findAll(),'name','name'),array('empty'=>'--請選擇節(jié)點--',
'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']); //通過節(jié)點名稱獲取該節(jié)點ID
$server = GossServer::model()->getServerByNodeid($nodeid); //通過節(jié)點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
/**
* 通過節(jié)點ID獲取該節(jié)點下所有的服務器名稱
* @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("找不到這個節(jié)點對應的服務器");
}
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'];
}
其它:
數據表結構
效果:
沒有選擇節(jié)點前:
細節(jié)有空再補上了。
cdnauto/views/config/index.php
復制代碼 代碼如下:
echo CHtml::dropDownList('node', '', CHtml::listData(Node::model()->findAll(),'name','name'),array('empty'=>'--請選擇節(jié)點--',
'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']); //通過節(jié)點名稱獲取該節(jié)點ID
$server = GossServer::model()->getServerByNodeid($nodeid); //通過節(jié)點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
復制代碼 代碼如下:
/**
* 通過節(jié)點ID獲取該節(jié)點下所有的服務器名稱
* @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("找不到這個節(jié)點對應的服務器");
}
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'];
}
其它:
數據表結構
效果:
沒有選擇節(jié)點前:

細節(jié)有空再補上了。
您可能感興趣的文章:
- Yii2使用dropdownlist實現地區(qū)三級聯(lián)動功能的方法
- asp.net DropDownList實現二級聯(lián)動效果
- ASP.NET中DropDownList和ListBox實現兩級聯(lián)動功能
- DropDownList綁定數據表實現兩級聯(lián)動示例
- 使用jQuery實現dropdownlist的聯(lián)動效果(sharepoint 2007)
- asp.net省市三級聯(lián)動的DropDownList+Ajax的三種框架(aspnet/Jquery/ExtJs)示例
- Jquery實現無刷新DropDownList聯(lián)動實現代碼
- asp.net DropDownList 三級聯(lián)動下拉菜單實現代碼
- dropdownlist之間的互相聯(lián)動實現(顯示與隱藏)
- yii2中dropDownList實現二級和三級聯(lián)動寫法
相關文章
Laravel框架實現model層的增刪改查(CURD)操作示例
這篇文章主要介紹了Laravel框架實現model層的增刪改查(CURD)操作,結合實例形式分析了Laravel框架模型model層進行數據庫的增刪改查操作具體實現技巧,需要的朋友可以參考下2018-05-05