xml 绑定 select

我想要完成的:点击页面上一个按钮后,从XML文件中取出值,绑定到页面上的一个下拉框。

我遇到的问题:在firefox浏览器中一步步调试时,最后下拉框中会显示新绑定的值,但直接运行的话,点了按钮后页面没有反应。

我的代码如下:(这里只试着取出XML文档中的一个值)

<!--==========HTML代码=========-->

 

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">

<HTML>

 <HEAD>

  <script type = "text/javascript">

function initSelect(){

 

var xmlDoc=document.implementation.createDocument("","",null);

xmlDoc.async="false";

xmlDoc.load("options.xml");

 

var yourSelect = document.getElementById("yourSelect");

var option = xmlDoc.getElementsByTagName("option")[0];

var yourOption = document.createElement("option");

yourOption.text = option.textContent;

//yourOption.text = "text";

yourSelect.appendChild(yourOption);

}

  </script>

 </HEAD>

 

 <BODY>

  <input type = "button" value="按钮1" οnclick="initSelect()"/>

  <select id="yourSelect">

  </select>

 

 </BODY>

</HTML>

 

 

<!--=========XML文件(options.xml)内容========-->

 

<?xml version="1.0" encoding="utf-8"?>

<list>

<option>option1</option>

<option>option2</option>

<option>option3</option>

<option>option4</option>

</list>

最后找到问题的根源:

 设置异步加载时,语句xmlDoc.async="false"有误,不应该给false加引号。因为这样赋一个非空字符串给左边,相当于赋true给它。赋了true的话,

就意味着允许浏览器在加载完XML文件之前运行javascript脚本。这样就造成运行脚本的时候还没有加载完XML文件,所以根本取不到值。而在调试的时候,

有一步步解析代码,这样就有了足够的时间去加载XML文件。所以调试的时候总可以看到正确结果,而一旦真的运行起来,页面上却没了反应。

 

 

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值