网络编程
位置:首页>> 网络编程>> XML编程>> Javascript调用XML制作连动下拉框(2)

Javascript调用XML制作连动下拉框(2)

  发布时间:2007-09-17 12:55:00 

标签:xml,下拉框,连动下拉框
 


HTML 文件如下:
<!-- myfile.html -->



<html> 
<head> 
<script language="JavaScript" for="window" event="onload"> 
var xmlDoc = new ActiveXObject("Microsoft.XMLDOM"); 
var i=0; 
var j=0; 
var subclass_name=""; 
loadXML(); 
function loadXML(){ 
xmlDoc.async="false"; 
xmlDoc.load("account.xml"); 
xmlObj=xmlDoc.documentElement;  
nodes = xmlDoc.documentElement.childNodes; 
document.frm.mainclass.options.length = 0;  
document.frm.subclass.options.length = 0; 
for (i=0;i<xmlObj.childNodes.length;i++){ 
labels=xmlObj.childNodes(i).getAttribute("display_name"); 
values=xmlObj.childNodes(i).text; 
document.frm.mainclass.add(document.createElement("OPTION")); 
document.frm.mainclass.options[i].text=labels;  
document.frm.mainclass.options[i].value=values;  


</script> 
<script language="JavaScript" > 
var xmlDoc = new ActiveXObject("Microsoft.XMLDOM"); 
var i=0; 
var j=0; 
function deleteOption() { 
     

function setsubclass(main){ 
var is_selected="N"; 
if (document.frm.subclass.options.length!=0) {  
for (i=0;i<=document.frm.subclass.options.length;i++) 
document.frm.subclass.options[i]=null ; 

//重复才有效 
if (document.frm.subclass.options.length!=0) {  
for (i=0;i<=document.frm.subclass.options.length;i++){ 
document.frm.subclass.options[i]=null ; 
document.frm.subclass.options.remove(i); 


for (i=0;i<xmlObj.childNodes.length;i++){ 
var values=""; 
var lables=""; 
if (is_selected=="Y") return; 
labels=xmlObj.childNodes(i).getAttribute("display_name"); 
values=xmlObj.childNodes(i).text; 
//alert(labels+ " | "+main); 
if (labels==main){ 
is_selected="Y"; 
for (j=0;j<xmlObj.childNodes(i).childNodes.length;j++){ 
//subclass_name="document.frm.subclass"; 
labels=xmlObj.childNodes(i).childNodes(j).getAttribute("display_name"); 
values=xmlObj.childNodes(i).childNodes(j).text; 
//alert(values);  
document.frm.subclass.add(document.createElement("OPTION")); 
document.frm.subclass.options[j].text=labels;  
document.frm.subclass.options[j].value=values;  




</script> 
<title>在HTML中调用XML数据</title> 
</head> 
<body bgcolor="#FFFFFF"> 
<FORM >  
类型<SELECT ></SELECT> 
<option selected value=""  ></option> 
子类<SELECT ></SELECT> 
</form> 
</body> 
</html>


account.xml 如下:


以下是引用片段:

<?xml version="1.0" encoding="GB2312"?> 
<item> 
<class display_name="未选定"> 
<subclass display_name="">Not Available</subclass>  
</class> 
<class display_name="95788主叫卡"> 
<subclass display_name="1152069589-1152069638">dangdang1</subclass>  
<subclass display_name="1152081031-1152081080">dangdang2</subclass> 
<subclass display_name="1152547201-1105254750">dangdang3</subclass> 
<subclass display_name="1152548401-1152548700">dangdang4</subclass> 
<subclass display_name="1152548701-1152549000">dangdang5</subclass> 
<subclass display_name="1156000001-1156010000">dangdang6</subclass> 
</class> 
<class display_name="网上注册"> 
<subclass display_name="1152000001-1152001000">zhuce_user1</subclass>  
<subclass display_name="1151001000-1151005000">zhuce_user2</subclass> 
</class> 
<class display_name="通讯"> 
<subclass display_name="1156030001-1156080000">tongxun</subclass>  
</class> 
</item>

此方法将数据源与javascript程序分开,适合经常变化的数据源。xmlDoc.load中可以直接调用URL参数,读取远程XML,实现松耦合。以上应用在IE6.0中通过。不足之处是在去除下拉框列表内容时需要重复执行删除操作,否则会有明显的bug.希望有读者能给指正。


0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com