montaque

小碗喝酒,小口吃肉

博客园 首页 新随笔 联系 订阅 管理
  119 Posts :: 1 Stories :: 680 Comments :: 17 Trackbacks
最近一个同事使用 asp.net 2.0 的Menu控件, 这个控件是asp.net 2.0 导航控件中的一个. 最近发现了一个问题, 把这个控件放在masterpage中. 然后一个页面使用该masterpage.

发现当页面加载没有结束,迅速点击 菜单的时候.会报一个IE特有的错误.呵呵.



Google 一下的,这个错误非常多. 也有人用asp.net menu的时候碰到类似的错误.比如:
http://forums.asp.net/thread/1158791.aspx

http://forums.asp.net/thread/1159962.aspx

类似的程序用firefox 浏览却没有问题.  IE这个问题其实是一个很常见的错误,它一般会在document还没有加载结束, 有脚本动态的修改document状态的时候发生.

对于asp.net menu 我看了一下它自动生成的代码. asp.net 会动态的生成几个axd文件,其实就是js文件. 其中有类似的代码.

  if (!childFrame) {
                childFrame 
= document.createElement("iframe");
                childFrame.id 
= childFrameId;
                childFrame.src 
= (data.iframeUrl ? data.iframeUrl : "about:blank");
                childFrame.style.position 
= "absolute";
                childFrame.style.display 
= "none";
                childFrame.scrolling 
= "no";
                childFrame.frameBorder 
= "0";
                
if (parent.tagName.toLowerCase() == "html"{
                    document.body.appendChild(childFrame);
                }

                
else {
                    parent.appendChild(childFrame);
                }

            }

呵呵,果然有一个动态的appendchild的代码. 其实这个做法很不严谨, MS 写的代码, 有时候也会忽略一些问题.

万一document 还没有加载, appendchild 触发了怎么办?

呵呵,当我点的很快的时候, 正好是这个并发的场合. 类似线程同步一样. 这也是为什么IE会报错的员应. firefox对document的状态修改并发控制可能跟ie不一样.

接下来怎么修改呢?
1. 可以用把menu放到一个div中,首先设置visibility为hidden.
2. 等document 加载完之后,再设置visibility为visible.

        document.onreadystatechange=ShowMenu;
        
function ShowMenu()
        
{
            
if(document.readyState=="complete")
            
{
                document.getElementById(
"DivOfMenu").style.visibility="visible"
            }

        }

这样就可以搞定了.

如果可以修改script的话,给script加上一个Defer属性也可以解决.
posted on 2006-09-18 17:09 montaque 阅读(2404) 评论(4) 编辑 收藏

评论

#1楼 2006-09-18 19:00 aspnetx      
那个对话框好有诱惑性啊
每次进来都差点没习惯性的点一下

 回复 引用 查看   

#2楼 2006-09-19 11:12 出走的影子      
把menu放在一个<div>
把这个<div>放在form最后
然后用绝对定位(position:absolute)放到你要的位置

 回复 引用 查看   

#3楼[楼主] 2006-10-02 23:45 montaque      
@出走的影子
你这个应该也是可以的。

 回复 引用 查看   

你好,按照你的说法在css中设div的visibility为hidden,然后在masterpage中的body中加 <script type="text/javascript">
document.onreadystatechange=ShowMenu;
function ShowMenu()
{
if(document.readyState=="complete")
{
document.getElementById("nav-main").style.visibility="visible"
}
}
</script>
好像运行后还是会产生这个问题呀!

 回复 引用