国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

使用js+jquery實現(xiàn)無限極聯(lián)動

2024-05-06 15:47:34
字體:
供稿:網(wǎng)友
本篇文章是對可擴展的無限極聯(lián)動下拉選項的實例進行了分析介紹,需要的朋友參考下

今天工作需要寫樹形的聯(lián)動,于是寫了個可擴展的無限極聯(lián)動下拉選項
代碼寫的比較凌亂 先mark有空再整理



隨便截個圖!
先貼數(shù)據(jù)庫

idcategory_name 分類名pid 父分類idorders 排序

12222333101

2222211111

1244444110

5222211

6222211

1133320

13555555120

頁面代碼 用的SMARTY

復(fù)制代碼 代碼如下:


<div >
<select onChange="change('category_1');">
<option>請選擇分類</option>
<!-- {foreach from=$galleryCategory item=category} -->
<option value="{$category.id}">{$category.category_name}</option>
<!-- {/foreach} -->
</select>
</div>


$galleryCategory 去數(shù)據(jù)的PHP代碼為

復(fù)制代碼 代碼如下:


$sql = " select * from yl_gallery_category where pid = 0";
$galleryCategory = $db->query($sql);
$smarty->assign("galleryCategory",$galleryCategory);


用的原生態(tài)代碼 還是比較容易理解的
然后就是關(guān)鍵的 JS代碼了function change(val) {

復(fù)制代碼 代碼如下:


var str = val; //select的id
var num; //當(dāng)前級數(shù)
var id; // 分類id
num = str.substr(9,10);
//alert(num);
var nownum = parseInt(num)+1; // 將字符串轉(zhuǎn)換為數(shù)字
id = $("#"+str+"").val();
var r = /^[1-9]+[0-9]*]*$/; //正整數(shù)
if (!r.test(id)) {
//清空過時的選項
$("select").each(function(index){
if(index+1 > num) {
$(this).remove();
}
})

return false;
}
var url = 'gallery.php?act=category&pid='+id;
$.ajax({
type: "POST",
cache: false,
url: url,
datatype : 'json',
timeout : 3000,
success: function(result){
if ( result != 0) {
var html = "<select name=category_"+nownum+"id=category_"+nownum+" onChange=change('category_"+nownum+"'); >";
html += "<option>請選擇分類 </option>";
var datas = eval(result);
$.each(datas, function(i,val){
html += "<option value='"+val.id+"' >"+val.category_name+"</option>";
});
html += "</select>";

//清空過時的選項
$("select").each(function(index){
if(index+1 > num) {
$(this).remove();
}
})

$("#select").append(html);
} else {
          //清空過時的選項
$("select").each(function(index){
if(index+1 > num) {
$(this).remove();
}
})       }

},
error: false
});

}


AJAX 取數(shù)據(jù)的PHP代碼

復(fù)制代碼 代碼如下:


$sql = " select * from yl_gallery_category where pid = " .$pid;
$res = $db->query($sql);
if (empty($res)) {
$res = 0;
}
echo json_encode($res);


OK 大功告成!

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 肇州县| 绩溪县| 高碑店市| 修水县| 邹城市| 永丰县| 汽车| 贡嘎县| 克拉玛依市| 邮箱| 海宁市| 曲麻莱县| 寿宁县| 桃园市| 宣武区| 文昌市| 临湘市| 阳谷县| 汝南县| 罗源县| 顺平县| 成安县| 正安县| 白银市| 绩溪县| 句容市| 宣汉县| 米林县| 阳城县| 湖南省| 临颍县| 上思县| 雷山县| 龙里县| 黎川县| 张家川| 高密市| 永宁县| 茂名市| 密云县| 赤城县|