Jsp页面纵向滚动条定位

一、各浏览器下 scrollTop的差异:

       IE6/7/8/9:document.documentElement.scrollTop;

       Firefox:document.documentElement.scrollTop ;

       Chrome:document.body.scrollTop;

       注:标准浏览器是只认识documentElement.scrollTop的,但chrome却不认识这个,在有文档声明时,chrome也只认识document.body.scrollTop。

       由于在不同情况下,document.body.scrollTop与document.documentElement.scrollTop都有可能取不到值,那到底网页的scrollTop值怎么得到呢?难道又要用JavaScript进行判断?

       其实不必。因为document.body.scrollTop与document.documentElement.scrollTop两者有个特点,就是同时只会有一个值生效。比如document.body.scrollTop能取到值的时候,document.documentElement.scrollTop就会始终为0;反之亦然。所以,如果要得到网页的真正的scrollTop值,可以这样:

    var heightTop =document.body.scrollTop + document.documentElement.scrollTop;

        这两个值总会有一个恒为0,所以不用担心会对真正的scrollTop造成影响。

二、在操作前将滚动条的位置记录到Cookie中

    //获取滚动条位置的值       
    var heightTop = document.body.scrollTop + document.documentElement.scrollTop;

    //在cookie中记滚动条的位置
    setCookie("scrollName", heightTop);

三、根据记录滚动条位置的名字设置滚动条位置

    /**
     * 根据记录滚动条位置的名字设置滚动条位置
     * scrollName 滚动条位置
     */
    function scrollbacks(scrollName) { 
        if (getCookie(scrollName) != null){
            document.documentElement.scrollTop=getCookie(scrollName);
        } 
    }

四、在操作完成后调用scrollbacks方法设置滚动条位置

    //定位滚动条
    scrollbacks("scrollName");
五、其中用到setCookie和getCookie,可以参考我的另外一片文章。

你可能感兴趣的:(js)