.NET Framework 2.0 中 SmartNavigation 的实现

.NET Framework 2.0中的SmartNavigation相较于1.1版本进行了三项改进:新增状态参数__smartNavPostBack;改进CSS更新机制;优化脚本加载方式,采用新的loadScript函数确保脚本加载完成后再进行页面渲染。

   .NET Framework 2.0 中的 SmartNavigation和1.1中实现是一样的,但有三个地方有变动:
    第一个是增加了一个状态参数"__smartNavPostBack",它由一个隐藏域来实现的,在attachForm到IFrame __smartNav上的时候,动态插入到From中。他的状态在 window.__smartNav.init 被置为了true(默认是false),但是这个状态并没有在整个Smart Navigate的过程被使用,这个可能是给别的代码使用的状态,告诉别人这个页面已经是被Smart Navigation控制了。
    第二个是增加了对CSS更新的更新,怎么这么绕口呢?这是因为如果CSS文件是动态更新的,Smart Navigate也应该保证它能被更新到我们实际的那个document中去,而这个在1.1的实现中被M$忽略掉了。代码是:

None.gif        var ss = document.styleSheets;
ExpandedBlockStart.gif        for (var i = 0 ; i < ss.length; i++) {
InBlock.gif            ss[i].href = ss[i].href;
ExpandedBlockEnd.gif        }

    原理和我们常用 document.location = document.location一样了。
    第三个也是修复bug。1.1中对JScript更新的更新居然是采取的和更新CSS一样的方法,代码是:

None.gif        var sc = document.scripts;
None.gif        for (var i = 0; i < sc.length; i++)
ExpandedBlockStart.gif        {
InBlock.gif            sc[i].text = sc[i].text;
ExpandedBlockEnd.gif        }

    这个方法在2.0中被更改了,而把CSS用这个方法来更新了。为什么要这样做呢?我觉得是脚本的优先级高吧,因为如果页面依赖脚本,而脚本不能保证被更新,那么这个页面就什么都干不了,而CSS如果不能保证被更新,最多也就是显示外观有点问题。所以在2.0中,M$专门做了一个函数 window.__smartNav.loadScript 来更新Script,代码是:

ExpandedBlockStart.gif    window.__smartNav.loadScript = function() {
InBlock.gif        var allScriptLoaded = true;
InBlock.gif        var sc = document.scripts;
ExpandedSubBlockStart.gif        for (var i = 0; i < sc.length; i++) {
ExpandedSubBlockStart.gif            if (sc[i].src != null && sc[i].src.length > 0) {
ExpandedSubBlockStart.gif                if (sc[i].readyState != 'loaded' && sc[i].readyState != 'complete' && sc[i].readyState != 'interactive') {
InBlock.gif                    allScriptLoaded = false;
ExpandedSubBlockEnd.gif                }
ExpandedSubBlockEnd.gif            }
ExpandedSubBlockEnd.gif        }
ExpandedSubBlockStart.gif        if (allScriptLoaded) {
ExpandedSubBlockStart.gif            for (var i = 0; i < sc.length; i++) {
InBlock.gif                sc[i].text = sc[i].text;
ExpandedSubBlockEnd.gif            }
InBlock.gif            if (typeof(window.onload) == "string")
ExpandedSubBlockStart.gif            {
ExpandedSubBlockStart.gif                try { eval(window.onload) } catch (e) {};
ExpandedSubBlockEnd.gif            }
InBlock.gif            else if (window.onload != null)
ExpandedSubBlockStart.gif            {
ExpandedSubBlockStart.gif                try { window.onload() } catch (e) {};
ExpandedSubBlockEnd.gif            }
ExpandedSubBlockEnd.gif        }
ExpandedSubBlockStart.gif        else {
InBlock.gif            setTimeout('window.__smartNav.loadScript();', 100);
ExpandedSubBlockEnd.gif        }
ExpandedBlockEnd.gif    };

    这个函数是自触发的,如果脚本装载不能loaded、complete或interactive,它将以10Hz的频率去反复尝试。
   
    本来以为Framework 2.0的SmartNavigation能让人有个惊喜,因为近来被Gmail的WebMail刺激了,结果还是有那么一点点让人失望。


本文转自博客园鸟食轩的博客,原文链接:http://www.cnblogs.com/birdshome/,如需转载请自行联系原博主。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值