我想要完成的:点击页面上一个按钮后,从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文件。所以调试的时候总可以看到正确结果,而一旦真的运行起来,页面上却没了反应。