js+xml生成級聯(lián)下拉框代碼
更新時間:2012年07月24日 00:39:56 作者:
js+xml生成級聯(lián)下拉框代碼,需要的朋友可以參考下
需要默認選中時,定義一個變量 var cityId=城市id
下面是js代碼
function readxml() {
var XmlDoc = null;
if (window.ActiveXObject) {
XmlDoc = new ActiveXObject("Microsoft.XMLDOM");
XmlDoc.async = false;
XmlDoc.load(path + "/web/common/regions.xml");
browse = "ie";
} else if (document.implementation
&& document.implementation.createDocument) {
xmlDoc = document.implementation.createDocument('', '', null);
xmlDoc.load("regions.xml");
browse = "ff";
} else {
alert('未做與該瀏覽器的兼容!');
}
var root = XmlDoc.documentElement;
// 獲取根節(jié)點下面的省節(jié)點
var provinces = root.childNodes;
var province = document.getElementByIdx_x_x("province");
var cities = document.getElementByIdx_x_x("regId");
for ( var i = 0; i < provinces.length; i++) {
// 獲取省節(jié)點的name屬性的值
var name = provinces[i].getAttribute("name");
// 創(chuàng)建一個option
var opt = document_createElement_x_x("option");
// 為option添加文本
opt.a(document_createTextNode(name));
// 添加到父節(jié)點中
if(cityId!=null&&cityId!=""){
var citys=provinces[i].childNodes;
for(var j=0;j<citys.length;j++){
if(citys[j].getAttribute("id")==cityId){
opt.selected="selected";
for ( var j = 0; j < citys.length; j++) {
// 創(chuàng)建一個option
var opt1 = document_createElement_x_x("option");
opt1.value = citys[j].getAttribute("id");
// 為option添加文本
opt1.a(document_createTextNode(citys[j]
.getAttribute("name")));
// 添加到父節(jié)點中
if(citys[j].getAttribute("id")==cityId){
opt1.selected="selected";
}
cities.a(opt1);
}
}
}
}
province.a(opt);
}
province.onchange = function() {
var pce = document.getElementByIdx_x_x("province");
var opts = pce.options;
var opt1 = opts[pce.selectedIndex];
var name = opt1.innerText;
for ( var i = 0; i < provinces.length; i++) {
// 獲取省節(jié)點的name屬性的值
var name1 = provinces[i].getAttribute("name");
if (name == name1) {
cities.length = 1;// 每次改變的時候清空
var pros = provinces[i];
var citys = pros.childNodes;
for ( var j = 0; j < citys.length; j++) {
// 創(chuàng)建一個option
var opt1 = document_createElement_x_x("option");
opt1.value = citys[j].getAttribute("id");
// 為option添加文本
opt1.a(document_createTextNode(citys[j]
.getAttribute("name")));
// 添加到父節(jié)點中
cities.a(opt1);
}
}
}
}
}
下面是xml結(jié)構(gòu)
<?xml version="1.0" encoding="utf-8"?>
<regions>
<province name="湖北">
<city id="1" name="武漢" isOpen="1" />
<city id="2" name="黃岡" isOpen="1" />
<city id="19" name="襄樊" isOpen="1" />
<city id="22" name="鄂州" isOpen="0" />
<city id="24" name="黃石" isOpen="1" />
</province>
<province name="重慶">
<city id="23" name="重慶" isOpen="0" />
</province>
</regions>
下面是js代碼
復(fù)制代碼 代碼如下:
function readxml() {
var XmlDoc = null;
if (window.ActiveXObject) {
XmlDoc = new ActiveXObject("Microsoft.XMLDOM");
XmlDoc.async = false;
XmlDoc.load(path + "/web/common/regions.xml");
browse = "ie";
} else if (document.implementation
&& document.implementation.createDocument) {
xmlDoc = document.implementation.createDocument('', '', null);
xmlDoc.load("regions.xml");
browse = "ff";
} else {
alert('未做與該瀏覽器的兼容!');
}
var root = XmlDoc.documentElement;
// 獲取根節(jié)點下面的省節(jié)點
var provinces = root.childNodes;
var province = document.getElementByIdx_x_x("province");
var cities = document.getElementByIdx_x_x("regId");
for ( var i = 0; i < provinces.length; i++) {
// 獲取省節(jié)點的name屬性的值
var name = provinces[i].getAttribute("name");
// 創(chuàng)建一個option
var opt = document_createElement_x_x("option");
// 為option添加文本
opt.a(document_createTextNode(name));
// 添加到父節(jié)點中
if(cityId!=null&&cityId!=""){
var citys=provinces[i].childNodes;
for(var j=0;j<citys.length;j++){
if(citys[j].getAttribute("id")==cityId){
opt.selected="selected";
for ( var j = 0; j < citys.length; j++) {
// 創(chuàng)建一個option
var opt1 = document_createElement_x_x("option");
opt1.value = citys[j].getAttribute("id");
// 為option添加文本
opt1.a(document_createTextNode(citys[j]
.getAttribute("name")));
// 添加到父節(jié)點中
if(citys[j].getAttribute("id")==cityId){
opt1.selected="selected";
}
cities.a(opt1);
}
}
}
}
province.a(opt);
}
province.onchange = function() {
var pce = document.getElementByIdx_x_x("province");
var opts = pce.options;
var opt1 = opts[pce.selectedIndex];
var name = opt1.innerText;
for ( var i = 0; i < provinces.length; i++) {
// 獲取省節(jié)點的name屬性的值
var name1 = provinces[i].getAttribute("name");
if (name == name1) {
cities.length = 1;// 每次改變的時候清空
var pros = provinces[i];
var citys = pros.childNodes;
for ( var j = 0; j < citys.length; j++) {
// 創(chuàng)建一個option
var opt1 = document_createElement_x_x("option");
opt1.value = citys[j].getAttribute("id");
// 為option添加文本
opt1.a(document_createTextNode(citys[j]
.getAttribute("name")));
// 添加到父節(jié)點中
cities.a(opt1);
}
}
}
}
}
下面是xml結(jié)構(gòu)
復(fù)制代碼 代碼如下:
<?xml version="1.0" encoding="utf-8"?>
<regions>
<province name="湖北">
<city id="1" name="武漢" isOpen="1" />
<city id="2" name="黃岡" isOpen="1" />
<city id="19" name="襄樊" isOpen="1" />
<city id="22" name="鄂州" isOpen="0" />
<city id="24" name="黃石" isOpen="1" />
</province>
<province name="重慶">
<city id="23" name="重慶" isOpen="0" />
</province>
</regions>
您可能感興趣的文章:
- jQuery+PHP+MySQL實現(xiàn)無限級聯(lián)下拉框效果
- JQuery實現(xiàn)級聯(lián)下拉框效果實例講解
- jQuery制作簡潔的多級聯(lián)動Select下拉框
- JQuery異步加載無限下拉框級聯(lián)功能實現(xiàn)示例
- 基于jquery的無限級聯(lián)下拉框js插件
- 省市區(qū)三級聯(lián)動下拉框菜單javascript版
- jsp從數(shù)據(jù)庫獲取數(shù)據(jù)填充下拉框?qū)崿F(xiàn)二級聯(lián)動菜單的方法
- javascript實現(xiàn)省市區(qū)三級聯(lián)動下拉框菜單
- js實現(xiàn)的下拉框二級聯(lián)動效果
- jQuery實現(xiàn)級聯(lián)下拉框?qū)崙?zhàn)(5)
相關(guān)文章
深入理解javascript嚴(yán)格模式(Strict Mode)
Strict mode是JavaScript1.8.5引進的技術(shù),但還沒有瀏覽器確實可靠的實現(xiàn)了嚴(yán)格模式,所以使用時要小心并且多測試。Strict mode可以應(yīng)用于整個腳本,也可以適合于單個函數(shù)。2014-11-11
JavaScript創(chuàng)建對象的七種經(jīng)典方式分享
JavaScript 創(chuàng)建對象的方式有很多,通過 Object 構(gòu)造函數(shù)或?qū)ο笞置媪康姆绞揭部梢詣?chuàng)建單個對象,顯然這兩種方式會產(chǎn)生大量的重復(fù)代碼,并不適合量產(chǎn)。本文介紹了七種非常經(jīng)典的創(chuàng)建對象的方式,希望對大家有所幫助2022-11-11
基于Express框架使用POST傳遞Form數(shù)據(jù)
這篇文章主要為大家詳細介紹了基于Express框架使用POST傳遞Form數(shù)據(jù),具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-08-08
Electron去掉窗口邊框并添加關(guān)閉按鈕的實現(xiàn)步驟
在?Electron?中,如果你想去掉默認的窗口邊框(frame)并添加額外的按鍵,可以通過相關(guān)步驟實現(xiàn),下面小編給大家?guī)砹薊lectron去掉窗口邊框并添加關(guān)閉按鈕的實現(xiàn)步驟,感興趣的朋友一起看看吧2024-06-06

