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

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

IE5中用JavaScript跨frame加option问题

摘要: selectbox javascript frame 框架 选择框
<textarea readonly style="border:none;font-family:Courier New;line-height:150%;width:760px;overflow-y:visible">

跨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
</textarea>
↑返回目录
前一篇: 面向对象的JavaScript编程
后一篇: javascript 经典函数