站内搜索: 请输入搜索关键词

当前页面: 开发资料首页Javascript 专题IE5中用JavaScript跨frame加option问题

IE5中用JavaScript跨frame加option问题

摘要: IE5中用JavaScript跨frame加option问题
<tr> <td> <table cellSpacing=0 cellPadding=0 width="95%" border=0> <tr> <td class=NEWS id=zoom>

跨frame加option,以下代码在IE5中会出错,但在IE4、IE6、Opera6、NNx中都没有问题:

<script>function addOption(aSelect, optionId, optionName) {


newOption = new Option(optionName, optionId);
aSelect.options[aSelect.options.length] = newOption;}</script>


这样才是对的:
<script>function addOption(aSelect, optionId, optionName) {


ownerWindow = aSelect.document.parentWindow;
ownerWindow.newOption = new Option(optionName, optionId);
aSelect.options[aSelect.options.length] = ownerWindow.newOption;}
function crossFrameAddOption() {
var aSelect = parent.otherFrameName.document.forms[0].theSelectName;
addOption(aSelect , "id"+ aSelect.options.length, "name"+ aSelect.options.length);}</script><input type="button" onClick="crossFrameAddOption();" value="test">

微软的解释如下:
In general, at least in the older browser versions, performance seems to improve if you call methods on the target frame if they are stored there as well. This is particularly relevant when trying to add options to a select box in another frame. Make sure you create the option in that other frame so you are adding it to a local select box, instead of trying to cross frame boundaries.

http://msdn.microsoft.com/library/default.asp?url =/library/en-us/dnwebteam/html/Webteam02052002.asp </td></tr> <tr> <td></td></tr></table></td> </tr> </table>
↑返回目录
前一篇: 一则装载页面进度条
后一篇: 轻松实现删除确认