Проблемы с двумя полосами прокрутки? - PullRequest
0 голосов
/ 04 сентября 2011

После этого сообщения я провел тест, но у меня все еще есть небольшая проблема - на странице есть две полосы прокрутки, когда вы нажимаете для отображения изображения.

Мне не нужна фоновая полоса прокрутки при отображении изображения, мне нужна только полоса прокрутки в контейнере изображений.

Как я могу скрыть фоновую полосу прокрутки, не делая страницу нервной?

КСС,

#container-image {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow-x: auto;
    overflow-y: scroll;
    z-index:100;
}

HTML,

<p>Please scroll down until you see the click button</p>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
<a href="#" class="get-photo">click</a>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>

<div id="container-image" style="display:none">
    <ul id="items-image">
        <li><img src="winnie-the-pooh-2011-4.jpg"/></li>
    </ul>
</div>

JQuery,

$(document).ready(function(){
        $('.get-photo').click(function(){

            var object = $(this);
            var object_path = object.attr('href');
            var scroll_top = $(window).scrollTop();
            //alert(object_path);
            $('#container-image').show();
            return false;
        });

    });

Вот тест страница .

EDIT:

Просто удалось скрыть полосу прокрутки body и она работает на всех браузерах, поддерживающих IE8 - как я могу исправить IE ??

$(document).ready(function(){
        $('.get-photo').click(function(){
            $('body').css('overflow', 'hidden');
            var object = $(this);
            var object_path = object.attr('href');
            var scroll_top = $(window).scrollTop();
            var height_document = $(document).height();
            //alert(object_path);

            $('#background-photo').css({

                height:height_document + 'px',
                display:'block'

            });

            $('#container-image').show();
            return false;
        });

        $('#items-image img').click(function(){

            var object = $(this);
            $('body').css('overflow', 'auto');
            $('#container-image').hide();
            $('#background-photo').hide();
            return false;
        });

    });

EDIT:

Исправлено IE8:

$('body,html').css('overflow', 'hidden');

Ответы [ 2 ]

2 голосов
/ 04 сентября 2011

Установите overflow: hidden на теле во время отображения изображения, чтобы скрыть полосы прокрутки:

$('body').css('overflow', 'hidden');
1 голос
/ 04 сентября 2011

Я только что удалил в Firebug следующие стили:

overflow-x: auto;
overflow-y: scroll;

и я могу видеть фон без прокрутки. Попробуй.

Но в этом случае, если фоновое изображение больше, чем видимое окно браузера - вы никогда не сможете увидеть все изображение из-за position:fixed

...