javascript - div scrollbar not appearing - Stack Overflow

I use css infrequently, but I thought that the following should create a scrollable area.Instead, it

I use css infrequently, but I thought that the following should create a scrollable area. Instead, it seems to just hide all the text that doesn't fit but provides no way to scroll. Behavior seems the same in chrome/ie/firefox, so I'm guessing I'm just doing something wrong.

index.html

<!DOCTYPE HTML>
<html>
  <head>
    <link rel="stylesheet" type="text/css" href="css/style.css">
    <title>Foo</title>
  </head>
  <body>
    <div id="history" class="scroll-area">Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque ac euismod nulla. Fusce enim tortor, elementum ut volutpat non, interdum ut nunc. Vestibulum placerat mi vel risus ultricies non bibendum urna vestibulum. Curabitur volutpat, turpis vel suscipit accumsan, lectus nibh blandit sem, ut elementum massa tortor quis augue. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Duis cursus lacus ac diam sollicitudin tempor. Vivamus at sagittis lacus. Donec augue neque, cursus in tristique at, mattis vitae eros.
    </div>
  </body>
</html>

style.css

#history {
    height: 200px;
    width: 200px;
    border: 1px solid #666;
    padding: 8px;
}

.scroll-area {
    overflow-style: auto;
    overflow: hidden;
}

I use css infrequently, but I thought that the following should create a scrollable area. Instead, it seems to just hide all the text that doesn't fit but provides no way to scroll. Behavior seems the same in chrome/ie/firefox, so I'm guessing I'm just doing something wrong.

index.html

<!DOCTYPE HTML>
<html>
  <head>
    <link rel="stylesheet" type="text/css" href="css/style.css">
    <title>Foo</title>
  </head>
  <body>
    <div id="history" class="scroll-area">Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque ac euismod nulla. Fusce enim tortor, elementum ut volutpat non, interdum ut nunc. Vestibulum placerat mi vel risus ultricies non bibendum urna vestibulum. Curabitur volutpat, turpis vel suscipit accumsan, lectus nibh blandit sem, ut elementum massa tortor quis augue. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Duis cursus lacus ac diam sollicitudin tempor. Vivamus at sagittis lacus. Donec augue neque, cursus in tristique at, mattis vitae eros.
    </div>
  </body>
</html>

style.css

#history {
    height: 200px;
    width: 200px;
    border: 1px solid #666;
    padding: 8px;
}

.scroll-area {
    overflow-style: auto;
    overflow: hidden;
}

Share asked Apr 25, 2013 at 17:14 Alex PritchardAlex Pritchard 4,2506 gold badges35 silver badges49 bronze badges 2
  • did you try .scroll-area { overflow-y: scroll; overflow: hidden; } – proggrock Commented Apr 25, 2013 at 17:17
  • Thanks, everyone. The overflow: hidden was definitely the problem! Appreciate all the super fast responses. – Alex Pritchard Commented Apr 25, 2013 at 17:42
Add a ment  | 

6 Answers 6

Reset to default 2

Well you're using overflow-style which isn't supported in any major browser yet ..

Setting overflow to auto or scroll on .scroll-area will have the vertical scrollbar appear as expected

http://jsfiddle/kRcaR/1/

You should explicitly set overflow to auto (or to scroll if you need scrollbars appear all the time):

.scroll-area {
    overflow: auto;
}

DEMO: http://jsfiddle/aNTHx/

You need to set overflow: auto or if you just want the y-axis to scroll overflow-y: auto; overflow-x: hidden;

Your div should have this overflow styling for vertical scrolling:

.scroll-area {
  overflow-y: scroll;
}

Or if you want to scroll horizontal:

.scroll-area {
  overflow-x: scroll;
}

Your hiding the scroll bar with overflow: hidden;.

If you change to:

.scroll-area {
    overflow-style: auto;
    overflow: auto;
}

HTML

<div id="history" class="scroll-area">Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque ac euismod nulla. Fusce enim tortor, elementum ut volutpat non, interdum ut nunc. Vestibulum place
</div>

CSS

#history {
    height: 200px;
    width: 200px;
    border: 1px solid #666;
    padding: 8px;
}

.scroll-area {
    overflow-style: auto;
    overflow: scroll;
}

DEMO

http://jsfiddle/YxsLc/1/

EXPLANATION

If You want to scroll content in html elements You should use property overflow: scroll;

Goodluck in future code.

发布者:admin,转转请注明出处:http://www.yc00.com/questions/1743692565a4491208.html

相关推荐

  • javascript - div scrollbar not appearing - Stack Overflow

    I use css infrequently, but I thought that the following should create a scrollable area.Instead, it

    1天前
    30

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信