去除隐藏小程序右侧滚动条的两种方法

2024-04-20 16:58

本文主要是介绍去除隐藏小程序右侧滚动条的两种方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这是一篇追求完美的杠精文章


在测试小程序布局时会出现,滚动条穿透的现象,如图

👆某团的滚动条已穿透顶部自定义导航栏

自定义导航栏 一定要用 cover-view、 一定要用 cover-view 、一定要用 cover-view


或是 在一些不需要滚动条 提示页面长度的情况下显示滚动条 这就很难受


所以总结了两个目前确定能用的方法:

1、使用cover-view标签覆盖滚动条

2、使用scroll-view标签绕过滚动条

但各个方法都有各自的局限性

下面进入正题


1、用图层覆盖滚动条

cover-view 标签 在模拟器中虽被滚动条穿透 但真机实测中可以覆盖右侧滚动条 

毕竟人家牛逼到能覆盖原生组件之上的

cover-view 官方介绍 https://developers.weixin.qq.com/miniprogram/dev/component/cover-view.html

上呆🐎

 

页面 wxml

<!-- 覆盖滚动条 -->
<cover-view class='hsb' /><!-- 内容 -->
<view class='box'><block wx:for='{{list}}' wx:key='index'><view class='item' style='background:{{item}}' /></block>
</view>

页面 wxss


/* 覆盖滚动条 */
.hsb {width: 6px;height: 100%;position: fixed;top: 0;right: 0;background: #fff;
}/* 内容盒子 */
.box {padding: 0 10px;
}/* 内容 */
.item {width: 100%;height: 80px;border-radius: 10px;margin: 0 0 10px;opacity: 0.4;
}

页面 js

Page({/*** 生命周期函数--监听页面加载*/onLoad: function(options) {// 获取随机颜色function num() {let num = new String()for (let i = 0; i < 6; i++) {num += Math.floor(Math.random() * 10)}return '#' + num}// 获取随机颜色数组let arr = new Array()for (let i = 0; i < 20; i++) {arr.push(num())}// 视图传值this.setData({list: arr})}})

效果

注:模拟器仍会显示滚动条 但真机已没有滚动条显示

优点:在部分爷爷机上 页面滚动相比用scroll-view标签 滚动会顺畅一些 ,不容易发生内容抖动

缺点:右侧6px宽度已经完全遮住,无法显示全宽度,对界面设计风格有要求


2、绕过页面滚动条

只要内容高度不超过窗口高度就不会显示页面的滚动条

所以设置scroll-view高度等于窗口高度即可,而scroll-view的滚动条可以通过代码设置隐藏

scroll-view 官方介绍 https://developers.weixin.qq.com/miniprogram/dev/component/scroll-view.html

上呆🐎

 

页面wxml

<scroll-view scroll-y style='height:{{h}}px' ><view class='box'><block wx:for='{{list}}' wx:key='index'><view class='item' style='background:{{item}}' /></block></view>
</scroll-view>

页面wxss

/* 隐藏滚动条 */
::-webkit-scrollbar {width: 0;height: 0;color: transparent;
}.box {padding: 0 10px;
}.item {width: 100%;height: 80px;border-radius: 10px;margin: 0 0 10px;opacity: 0.4;
}

页面js

const app = getApp()
Page({data: {h: app.system.windowHeight - 1 //窗口高度 必须-1px 否则某些情况会显示滚动条},/*** 生命周期函数--监听页面加载*/onLoad: function(options) {// 获取随机颜色function num() {let num = new String()for (let i = 0; i < 6; i++) {num += Math.floor(Math.random() * 10)}return '#' + num}// 获取随机颜色数组let arr = new Array()for (let i = 0; i < 20; i++) {arr.push(num())}// 视图传值this.setData({list: arr})}
})

app.js

App({globalData: {},onLaunch: function() {//获取系统信息wx.getSystemInfo({success: res => {this.system = res}})}
})

效果略

注:页面js中 h = app.system.windowHeight - 1 的原因,

        很奇葩的地方是:不减1px 在模拟器上会显示滚动条 真机不显示;减1px后 模拟器上、真机上都不会显示滚动条

        而实测减1px高度对界面没有任何影响,规定统一减1px

优点:界面完全可用

缺点:部分机型视觉上可能会掉帧、抖动


这两种方法各有利弊,开发过程中,如某个页面确实需要隐藏滚动条,可根据不同的特点选择最优方案

 

 

另外我在微信小程序社区问了该问题,但官方的社区技术运营专员给我一个链接参考

地址 https://developers.weixin.qq.com/community/develop/doc/000a024b1a41905d509ac7f1055400

用了文中的方法但没有任何效果,大家可以试一试,踩对坑了别忘分享哦~

 

 

 

 

这篇关于去除隐藏小程序右侧滚动条的两种方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/920815

相关文章

504 Gateway Timeout网关超时的根源及完美解决方法

《504GatewayTimeout网关超时的根源及完美解决方法》在日常开发和运维过程中,504GatewayTimeout错误是常见的网络问题之一,尤其是在使用反向代理(如Nginx)或... 目录引言为什么会出现 504 错误?1. 探索 504 Gateway Timeout 错误的根源 1.1 后端

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

python 线程池顺序执行的方法实现

《python线程池顺序执行的方法实现》在Python中,线程池默认是并发执行任务的,但若需要实现任务的顺序执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录方案一:强制单线程(伪顺序执行)方案二:按提交顺序获取结果方案三:任务间依赖控制方案四:队列顺序消

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat

使用Java读取本地文件并转换为MultipartFile对象的方法

《使用Java读取本地文件并转换为MultipartFile对象的方法》在许多JavaWeb应用中,我们经常会遇到将本地文件上传至服务器或其他系统的需求,在这种场景下,MultipartFile对象非... 目录1. 基本需求2. 自定义 MultipartFile 类3. 实现代码4. 代码解析5. 自定

Python文本相似度计算的方法大全

《Python文本相似度计算的方法大全》文本相似度是指两个文本在内容、结构或语义上的相近程度,通常用0到1之间的数值表示,0表示完全不同,1表示完全相同,本文将深入解析多种文本相似度计算方法,帮助您选... 目录前言什么是文本相似度?1. Levenshtein 距离(编辑距离)核心公式实现示例2. Jac

C#高效实现Word文档内容查找与替换的6种方法

《C#高效实现Word文档内容查找与替换的6种方法》在日常文档处理工作中,尤其是面对大型Word文档时,手动查找、替换文本往往既耗时又容易出错,本文整理了C#查找与替换Word内容的6种方法,大家可以... 目录环境准备方法一:查找文本并替换为新文本方法二:使用正则表达式查找并替换文本方法三:将文本替换为图

SQL Server 查询数据库及数据文件大小的方法

《SQLServer查询数据库及数据文件大小的方法》文章介绍了查询数据库大小的SQL方法及存储过程实现,涵盖当前数据库、所有数据库的总大小及文件明细,本文结合实例代码给大家介绍的非常详细,感兴趣的... 目录1. 直接使用SQL1.1 查询当前数据库大小1.2 查询所有数据库的大小1.3 查询每个数据库的详

Java实现本地缓存的四种方法实现与对比

《Java实现本地缓存的四种方法实现与对比》本地缓存的优点就是速度非常快,没有网络消耗,本地缓存比如caffine,guavacache这些都是比较常用的,下面我们来看看这四种缓存的具体实现吧... 目录1、HashMap2、Guava Cache3、Caffeine4、Encache本地缓存比如 caff

Java 中编码与解码的具体实现方法

《Java中编码与解码的具体实现方法》在Java中,字符编码与解码是处理数据的重要组成部分,正确的编码和解码可以确保字符数据在存储、传输、读取时不会出现乱码,本文将详细介绍Java中字符编码与解码的... 目录Java 中编码与解码的实现详解1. 什么是字符编码与解码?1.1 字符编码(Encoding)1