使用js+jquery實(shí)現(xiàn)無(wú)限極聯(lián)動(dòng)
今天工作需要寫(xiě)樹(shù)形的聯(lián)動(dòng),于是寫(xiě)了個(gè)可擴(kuò)展的無(wú)限極聯(lián)動(dòng)下拉選項(xiàng)
代碼寫(xiě)的比較凌亂 先mark有空再整理

隨便截個(gè)圖!
先貼數(shù)據(jù)庫(kù)
| id | category_name 分類(lèi)名 | pid 父分類(lèi)id | orders 排序 |
|---|---|---|---|
| 1 | 22223331 | 0 | 1 |
| 2 | 2222111 | 1 | 1 |
| 12 | 44444 | 11 | 0 |
| 5 | 2222 | 1 | 1 |
| 6 | 2222 | 1 | 1 |
| 11 | 333 | 2 | 0 |
| 13 | 555555 | 12 | 0 |
頁(yè)面代碼 用的SMARTY
<div id="select" >
<select name="category_1" id="category_1" onChange="change('category_1');">
<option>請(qǐng)選擇分類(lèi)</option>
<!-- {foreach from=$galleryCategory item=category} -->
<option value="{$category.id}">{$category.category_name}</option>
<!-- {/foreach} -->
</select>
</div>
$galleryCategory 去數(shù)據(jù)的PHP代碼為
$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) {
var str = val; //select的id
var num; //當(dāng)前級(jí)數(shù)
var id; // 分類(lèi)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)) {
//清空過(guò)時(shí)的選項(xiàng)
$("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>請(qǐng)選擇分類(lèi) </option>";
var datas = eval(result);
$.each(datas, function(i,val){
html += "<option value='"+val.id+"' >"+val.category_name+"</option>";
});
html += "</select>";
//清空過(guò)時(shí)的選項(xiàng)
$("select").each(function(index){
if(index+1 > num) {
$(this).remove();
}
})
$("#select").append(html);
} else {
//清空過(guò)時(shí)的選項(xiàng)
$("select").each(function(index){
if(index+1 > num) {
$(this).remove();
}
}) }
},
error: false
});
}
AJAX 取數(shù)據(jù)的PHP代碼
$sql = " select * from yl_gallery_category where pid = " .$pid;
$res = $db->query($sql);
if (empty($res)) {
$res = 0;
}
echo json_encode($res);
OK 大功告成!
- JS無(wú)限極樹(shù)形菜單,json格式、數(shù)組格式通用示例
- asp實(shí)現(xiàn)無(wú)限級(jí)分類(lèi)的方法js版
- js實(shí)現(xiàn)無(wú)限級(jí)樹(shù)形導(dǎo)航列表效果代碼
- JS實(shí)現(xiàn)無(wú)限級(jí)網(wǎng)頁(yè)折疊菜單(類(lèi)似樹(shù)形菜單)效果代碼
- json+jQuery實(shí)現(xiàn)的無(wú)限級(jí)樹(shù)形菜單效果代碼
- javascript實(shí)現(xiàn)無(wú)限級(jí)select聯(lián)動(dòng)菜單
- 基于jquery的無(wú)限級(jí)聯(lián)下拉框js插件
- JavaScript+CSS無(wú)限極分類(lèi)效果完整實(shí)現(xiàn)方法
相關(guān)文章
jQuery效果 slideToggle() 方法(在隱藏和顯示之間切換)
slideToggle() 方法通過(guò)使用滑動(dòng)效果(高度變化)來(lái)切換元素的可見(jiàn)狀態(tài)。2011-06-06
jQuery實(shí)現(xiàn)的導(dǎo)航下拉菜單效果
這篇文章主要介紹了jQuery實(shí)現(xiàn)的導(dǎo)航下拉菜單效果,涉及jQuery響應(yīng)鼠標(biāo)事件動(dòng)態(tài)操作頁(yè)面元素的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-07-07
jQuery實(shí)現(xiàn)自定義checkbox和radio樣式
這篇文章主要介紹了jQuery實(shí)現(xiàn)自定義checkbox和radio樣式的相關(guān)資料,需要的朋友可以參考下2015-07-07
webpack中引用jquery的簡(jiǎn)單實(shí)現(xiàn)
下面小編就為大家?guī)?lái)一篇webpack中引用jquery的簡(jiǎn)單實(shí)現(xiàn)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-06-06
Ajax分頁(yè)插件Pagination從前臺(tái)jQuery到后端java總結(jié)
這篇文章主要從前臺(tái)jQuery到后java端總結(jié)了Ajax分頁(yè)插件Pagination的使用方法和技巧,感興趣的小伙伴們可以參考一下2016-07-07
使用jQuery實(shí)現(xiàn)Form表單提交操作
在Web開(kāi)發(fā)中,表單提交是一個(gè)常見(jiàn)的操作,通過(guò)表單提交用戶(hù)可以向服務(wù)器發(fā)送數(shù)據(jù),jQuery是一個(gè)流行的JavaScript庫(kù),可以簡(jiǎn)化處理JavaScript的操作,包括表單提交,在本篇博客中,我們將介紹如何使用jQuery來(lái)實(shí)現(xiàn)表單提交操作,需要的朋友可以參考下2024-09-09
jquery中checkbox使用方法簡(jiǎn)單實(shí)例演示
這篇文章主要介紹了jquery中checkbox使用方法簡(jiǎn)單實(shí)例演示,感興趣的小伙伴們可以參考一下2015-11-11

