用css修改scroll样式


我实现的是一种黑灰的滚动条     有兴趣的可以直接粘贴代码运行看效果

1.给需要设置滚动条的容器加上class="topnav_box"     

 

2.接下来是css.,

.topnav_box::-webkit-scrollbar    //滚动条整体部分

{  
    width: 5px;  

    height:10px;     

   background-color:#b5b1b1;

}  
.topnav_box::-webkit-scrollbar-track       //scroll轨道背景
{  
    -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.3);  
    border-radius: 10px; 
      background-color:black;    
    
}




.topnav_box::-webkit-scrollbar-thumb  滚动条中能上下移动的小块
{  
    border-radius: 10px;  
    -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,.3);  
   background-color:#b5b1b1;

 

3.自定义滚动条

滚动条组成:

 

  • ::-webkit-scrollbar 滚动条整体部分
  • ::-webkit-scrollbar-thumb  滚动条里面的小方块,能向上向下移动(或往左往右移动,取决于是垂直滚动条还是水平滚动条)
  • ::-webkit-scrollbar-track  滚动条的轨道(里面装有Thumb)
  • ::-webkit-scrollbar-button 滚动条的轨道的两端按钮,允许通过点击微调小方块的位置。
  • ::-webkit-scrollbar-track-piece 内层轨道,滚动条中间部分(除去)
  • ::-webkit-scrollbar-corner 边角,即两个滚动条的交汇处
  • ::-webkit-resizer 两个滚动条的交汇处上用于通过拖动调整元素大小的小控件

 

 

 

 

修改 `scroll-view` 下拉刷新的样式,需要在 `scroll-view` 中添加下拉刷新组件,并设置其相应的样式。 以下是一个示例代码: ```html <scroll-view class="scrollview" scroll-y bindscrolltolower="scrolltolower" bindscrolltoupper="scrolltoupper"> <view class="refresh-view" style="height:{{refreshHeight}}px;"> <image class="refresh-image" src="../../static/img/refresh.png"></image> <view class="refresh-text">{{refreshText}}</view> </view> <!-- 此处为scroll-view的内容 --> </scroll-view> ``` 其中,`refresh-view` 为下拉刷新的容器,`refresh-image` 为下拉刷新的图标,`refresh-text` 为下拉刷新的文字。 接着,在 js 文件中设置下拉刷新的相关逻辑和样式: ```javascript Page({ data: { refreshHeight: 0, refreshText: '下拉刷新', refreshAnimation: {} }, // touchstart事件,记录下拉刷新的初始位置 touchstart: function (e) { this.setData({ startY: e.changedTouches[0].clientY }) }, // touchmove事件,计算下拉刷新的距离并更新样式 touchmove: function (e) { var moveY = e.changedTouches[0].clientY var disY = moveY - this.data.startY if (disY < 0) { return } var scrollHeight = this.data.scrollHeight var refreshHeight = this.data.refreshHeight var progress = disY / (refreshHeight + 10) * 100 if (progress > 100) { progress = 100 } var refreshText = '' if (progress < 20) { refreshText = '下拉刷新' } else if (progress < 80) { refreshText = '释放立即刷新' } else { refreshText = '正在刷新...' } this.setData({ refreshHeight: disY, progress: progress, refreshText: refreshText }) }, // touchend事件,触发下拉刷新并更新样式 touchend: function (e) { var refreshHeight = this.data.refreshHeight var scrollHeight = this.data.scrollHeight var progress = this.data.progress if (progress < 80) { this.setData({ refreshHeight: 0, refreshText: '下拉刷新' }) } else { this.setData({ refreshHeight: 50, refreshText: '正在刷新...' }) // 触发下拉刷新 this.refreshData() } }, // scrolltolower事件,触发上拉加载更多 scrolltolower: function () { // 触发上拉加载更多 this.loadMoreData() }, // scrolltoupper事件,触发下拉刷新 scrolltoupper: function () { this.setData({ refreshHeight: 50, refreshText: '正在刷新...' }) // 触发下拉刷新 this.refreshData() }, // 下拉刷新的逻辑 refreshData: function () { // 下拉刷新的具体实现 }, // 上拉加载更多的逻辑 loadMoreData: function () { // 上拉加载更多的具体实现 } }) ``` 在 css 文件中设置相应的样式: ```css .scrollview { height: 100%; overflow: auto; } .refresh-view { display: flex; justify-content: center; align-items: center; height: 0; transition: height 0.3s; } .refresh-image { width: 20px; height: 20px; margin-right: 10px; } .refresh-text { font-size: 14px; color: #666; } ``` 这样就可以实现自定义 `scroll-view` 下拉刷新的样式了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值