使用CSS实现无滚动条滚动的两种方法
GPT4.0+Midjourney绘画+国内大模型 会员永久免费使用!
【 如果你想靠AI翻身,你先需要一个靠谱的工具! 】
我们都知道,撸页面的时候当我们的内容超出了我们的div,往往会出现滚动条,影响美观。
尤其是当我们在做一些导航菜单的时候。滚动条一出现就破坏了UI效果。 我们不希望出现滚动条,也不希望超出去的内容被放逐,就要保留鼠标滚动的效果。我们都知道overflow:hidden是可以隐藏滚动条的,但存在的问题是:页面或元素失去了滚动的特性,进而溢出内容也变得不可见,这样肯定是不可取的。百度下大部分都是在说overflow:hidden或者overflow-y: no可以解决问题,但是并不能很好的解决我们的问题,那么怎么办呢?
接下来小萌介绍几种简单的方法,但是也不是完美的解决问题了,各求所需吧
第一种:伪对象选择器
在webkit内核的浏览器里可以定义滚动条样式。在CSS初始处定义
不过目前本方法只在webkit内核浏览器中有效(Chrome,Safari)。
第二种:变相隐藏
大体思路是在div外面再套一个div。这个div设置overflow:hidden。而内容div设置 overflow-x: hidden;overflow-y: scroll;然后再设置外层div的width小于内容div的width,就是用一个无滚动条的div包裹另一个有滚动条的div,从而实现隐藏滚动条的效果。
例子:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 | <!DOCTYPE html> <html> <head> <title>使用CSS实现无滚动条滚动</title> <meta charset= "UTF-8" > <style type= "text/css" > body,html { margin : 0 ; padding : 0 ; height : 100% ; overflow : hidden ; } ul,li { margin : 0 ; padding : 0 ; list-style : none ; } .box_wrap { margin : 20px auto ; width : 200px ; height : 400px ; border : 1px solid #ccc ; overflow : hidden ; } .box_wrap ul { width : 220px ; /* 多出20像素是滚动条的位置,会被父容器盖住就看不到了 */ height : 100% ; overflow-x: hidden ; overflow-y: auto ; } .box_wrap ul li { width : 200px ; height : 40px ; line-height : 40px ; border-bottom : 1px solid #ccc ; font-size : 12px ; text-align : center ; } </style> </head> <body> <div class= "box_wrap" > <ul> <li>测试数据 1 </li> <li>测试数据 2 </li> <li>测试数据 3 </li> <li>测试数据 4 </li> <li>测试数据 5 </li> <li>测试数据 6 </li> <li>测试数据 7 </li> <li>测试数据 8 </li> <li>测试数据 9 </li> <li>测试数据 10 </li> <li>测试数据 11 </li> <li>测试数据 12 </li> <li>测试数据 13 </li> <li>测试数据 14 </li> <li>测试数据 15 </li> <li>测试数据 16 </li> <li>测试数据 17 </li> <li>测试数据 18 </li> <li>测试数据 19 </li> <li>测试数据 20 </li> <li>测试数据 21 </li> <li>测试数据 22 </li> <li>测试数据 23 </li> <li>测试数据 24 </li> <li>测试数据 25 </li> <li>测试数据 26 </li> <li>测试数据 27 </li> <li>测试数据 28 </li> <li>测试数据 29 </li> <li>测试数据 30 </li> </ul> </div> </body> </html> |
总结
以上所述是小编给大家介绍的使用CSS实现无滚动条滚动功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
相关文章
如何使用CSS的object-position实现图片在img标签中的定位
该文章介绍了CSS中的object-position属性,用于精确控制替换元素在容器内的位置,通过指定水平和垂直方向的偏移量,可以实现精准定位2024-11-08- 文章主要探讨了CSS Grid布局在Internet Explorer(IE)中的不兼容问题,并提供了具体的解决方案和最佳实践,文章首先介绍了CSS Grid布局的基本概念和与传统布局方法的区别,然2024-11-08
- 本文介绍了CSS实现圆角渐变边框的方法,首先设置元素边框为1像素宽度,样式为实线,颜色为透明,然后设置元素边框圆角为10像素,再设置背景剪裁区域和背景绘制区域为内边距和边2024-10-29
- 在CSS布局中,实现元素左右排列有多种方式,Flex布局通过设置margin-left:auto或margin-right:auto实现元素靠右或靠左排列,Grid布局利用grid-template-columns和justify-self2024-10-29
- 在CSS中,隐藏滚动条同时保留滚动功能可以通过设置overflow属性和使用特定的CSS伪元素实现,例如,使用::-webkit-scrollbar针对WebKit浏览器,-ms-overflow-style适用于IE和Edg2024-10-29
- 本文详细介绍了CSS中的border属性及其相关特性,包括border-width(宽度)、border-style(样式)和border-color(颜色)等,此外,还讲述了如何独立控制元素的四个边的边框,2024-10-28
- 本文主要介绍了在网页开发中如何实现“回到顶部”的功能,通过HTML和CSS的编写,可以实现一个浮动在页面右下角的小图标,点击后即可回到页面顶部,这种设计可以提高网站的可用2024-10-28
- 盒子模型是网页布局的基础,包括边框、外边距、内边距和实际内容,通过CSS可以控制盒子之间的距离及其外观,如边框样式、边框颜色等,重要属性包括padding和margin,分别控制内2024-10-18
- 盒子模型是网页布局的基础,包括边框、外边距、内边距和实际内容,通过CSS可以控制盒子之间的距离及其外观,如边框样式、边框颜色等,重要属性包括padding和margin,分别控制内2024-10-18
CSS使用filter和backdrop-filter实现高斯模糊效果(示例代码)
本文详细介绍了CSS3中的两个实现高斯模糊效果的API:filter和backdrop-filter,filter可以直接在图像或背景图上添加多种效果,而backdrop-filter则用于在元素后的区域添加效2024-09-26
最新评论