网络编程
位置:首页>> 网络编程>> 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
投稿

猜你喜欢

  • 本文介绍FCKeditor在Java环境下的使用方法。一、简介 功能:所见即所得,支持图片和Flash,工具栏可自由配置,使用简单兼容性:I
  • 代码如下:declare @cmd nvarchar(4000) set @cmd = N'exec [?].sys.sp_chan
  • kelon 问:格式如下:s="地,在要,大,奇功,不知,但是,不示"我想把它split分出來,变成数组來循环,但是不知
  • <style> body {margin:10px;background-color:#ffffff;margin-t
  • 讲这个方法之前,我们应该先了解下插入节点时浏览器会做什么。在浏览器中,我们一旦把节点添加到document.body(或者其他节点)中,页面
  • 对于个人站长来说,如何能使自己的网站与众不同、充满个性,一直是不懈努力的目标。除了尽量提高页面的视觉效果、互动功能以外,如果能在打开网页的同
  • 面对不断成长的用户,跟随用户的脚步齐步向前,做引起共鸣的改变,去除低龄化的设计,用成熟稳重的心态面对用户。QQBanner自2006 年推出
  • 本文帮你六步改善SQL Server安全规划全攻略。一、什么是SQL注入式攻击所谓SQL注入式攻击,就是攻击者把SQL命令插入到Web表单的
  • 有时候,我们需要替换指定标签外的内容,而保留标签里面的内容不替换。比如当我们要在浏览器中显示出编辑器显示的原始格式时、需要将普通换行符“\n
  • 本篇文章适合css新手学习,对于已经掌握了css的朋友们也可以通过本片文章来复习知识。作者通过实践,认为在有些情况下css的代码是可以更加简
  • 交互设计是近几年流行的一个词语。现在市场上有许多资料来介绍什么是交互设计,如何做交互设计等。从场景,任务,用户,操作等分析。但由于受实际情况
  • 当你要使用data URI scheme的时候,你会发现,虽然他可以使用在绝大多数浏览器上,但无法再IE6和IE7上工作。不过值得庆幸的这一
  • LOAD DATA INFILE '文件地址' INTO TABLE 表名 FIELDS TERMINATED BY 
  • 以一种有意义的方式组织数据可能是一项挑战。有时你需要的可能是一个简单的排序,但是通常你需要做更多,你需要分组来进行分析和统计。幸运的是,SQ
  • IE的特殊性  IE的DOM元素属性与Firefox, Opera, Safari有些不同。在IE中,我们可以给DOM添加任意自定
  • SQL Server所谓的分布式查询(Distributed Query)是能够访问存放在同一部计算机或不同计算机上的SQL Server或
  • 搞前端应该对语义化并不陌生,每天都在说语义化,可什么是语义化,语义化究竟能给我们带来什么好处?参加web标准交流会的时候我向各位同学提出了我
  • 验证关键词是否为sql保留字的在线工具:<html>      <head><t
  • 最近,在项目开发过程中,碰到了数据库死锁问题,在解决问题的过程中,笔者对MySQL InnoDB引擎锁机制的理解逐步加深。案例如下:在使用S
  • number(<p>,<s>)精度p取值范围1~38有效位s取值范围-84~127最高整数位数=p-ss正数,小数点
手机版 网络编程 asp之家 www.aspxhome.com