詳解微信小程序scroll-view橫向滾動(dòng)的實(shí)踐踩坑及隱藏其滾動(dòng)條的實(shí)現(xiàn)
一、實(shí)踐踩坑
項(xiàng)目使用mpvue開發(fā)
1. scroll-view默認(rèn)是不滾動(dòng)的。。所以要先設(shè)置scroll-x="true"或者scroll-y="true"

2. 在scroll-view里面添加定寬元素,超過scroll-view寬度(設(shè)置了100%,即屏幕寬度)后,它竟然換行了。所以要scroll-view的樣式要這樣設(shè)置:
scroll-view {
width: 100%;
white-space: nowrap; // 不讓它換行
}
3. 然后在定寬元素里邊添加子容器:
// html大概長(zhǎng)這樣
<scroll-view scroll-x="true">
<div class="tab-item">
<img class="content-icon"/>
<div></div>
</div>
<div class="tab-item">
<img class="content-icon"/>
<div></div>
</div>
<div class="tab-item">
<img class="content-icon"/>
<div></div>
</div>
</scroll-view>
// css相應(yīng)就大概長(zhǎng)這樣
scroll-view {
display: flex;
flex-wrap: nowrap;
}
.tab-item {
display: flex;
justify-content: center;
width: 25%;
...
}
然后發(fā)現(xiàn).tab-item并沒有排在一行上。。說明scroll-view和.tab-item都設(shè)置display: flex無效?無奈之下,只好在它外邊再包一層,然后樣式設(shè)置display: inline-block。此時(shí)正確姿勢(shì)如下:
// html
<div class="scroll-view-container">
<scroll-view scroll-x="true" :scroll-into-view="toView">
<div class="tab-container">
<div class="tab-item">
<img class="content-icon"/>
<div></div>
</div>
</div>
</scroll-view>
</div>
// css變成這樣子
scroll-view {
width: 100%;
white-space: nowrap; // 不讓它換行
}
.tab-container {
display: inline-block;
width: 25%;
}
.tab-item {
display: flex;
flex-direction: column;
align-items: center;
...
}
到這里,scroll-view就基本如我所愿了,大概長(zhǎng)這樣:

二、隱藏滾動(dòng)條
在網(wǎng)上搜了很多,都是說加上這段代碼就可以:
/*隱藏滾動(dòng)條*/
::-webkit-scrollbar{
width: 0;
height: 0;
color: transparent;
}
或者有的人說這樣子:
/*隱藏滾動(dòng)條*/
::-webkit-scrollbar{
display: none;
}
然而兩種方法我都試過,scroll-view的滾動(dòng)條依然存在。。測(cè)試機(jī)型是安卓機(jī)子。
但是用display: none這種方法是可以隱藏掉頁面的滾動(dòng)條的,就是scroll-view的滾動(dòng)條沒隱藏掉。
后來,在小程序社區(qū)看到官方人員這樣子解答:

是的,就是這種野路子。當(dāng)然 ,它下面的評(píng)論里也有人提供了另一種解決思路方法,但我還是選擇了官方說的那種野路子方法。傳送門
實(shí)現(xiàn)思路就是,在scroll-view外邊再包一個(gè)容器,它的高度小于scroll-view的高度,這樣就會(huì)截掉滾動(dòng)條,達(dá)到隱藏了滾動(dòng)條的效果。
// scss
.scroll-view-container { // 包裹scroll-view的容器
height: $fakeScrollHeight;
overflow: hidden; // 這個(gè)設(shè)置了就能截掉滾動(dòng)條啦
scroll-view {
width: 100%;
white-space: nowrap;
}
}
.tab-container { // 我這里是用.tab-container來撐開scroll-view的高度,所以高度在它上面設(shè)置,加上padding,那么它就會(huì)比外層容器(.scroll-view-container)要高
display: inline-block;
width: 26%;
height: $fakeScrollHeight;
padding-bottom: $scrollBarHeight;
}
大概意思是這樣:

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 微信小程序?qū)崿F(xiàn)橫向滾動(dòng)條
- 微信小程序?qū)崿F(xiàn)滾動(dòng)條功能
- 微信小程序scroll-view隱藏滾動(dòng)條的方法詳解
- 微信小程序scroll-view的滾動(dòng)條設(shè)置實(shí)現(xiàn)
- 微信小程序設(shè)置滾動(dòng)條過程詳解
- 微信小程序?qū)崿F(xiàn)swiper切換卡內(nèi)嵌滾動(dòng)條不顯示的方法示例
- 微信小程序scroll-view仿拼多多橫向滑動(dòng)滾動(dòng)條
- 微信小程序-橫向滑動(dòng)scroll-view隱藏滾動(dòng)條
- 微信小程序 scroll-view隱藏滾動(dòng)條詳解
- 微信小程序scroll-view實(shí)現(xiàn)自定義滾動(dòng)條
相關(guān)文章
微信小程序?qū)崿F(xiàn)的涂鴉功能示例【附源碼下載】
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)的涂鴉功能,涉及微信小程序事件響應(yīng)及畫筆的相關(guān)操作技巧,并附帶源碼供讀者下載參考,需要的朋友可以參考下2018-01-01
confirm確認(rèn)對(duì)話框的實(shí)現(xiàn)方法總結(jié)
下面小編就為大家?guī)硪黄猚onfirm確認(rèn)對(duì)話框的實(shí)現(xiàn)方法總結(jié)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-06-06
Javascript 中的 call 和 apply使用介紹
JavaScript 中通過call或者apply用來代替另一個(gè)對(duì)象調(diào)用一個(gè)方法,將一個(gè)函數(shù)的對(duì)象上下文從初始的上下文改變?yōu)橛?thisObj 指定的新對(duì)象2012-02-02
javascript之鼠標(biāo)拖動(dòng)位置互換效果代碼
javascript之鼠標(biāo)拖動(dòng)位置互換效果代碼...2007-11-11
js的隱含參數(shù)(arguments,callee,caller)使用方法
本篇文章只要是對(duì)js的隱含參數(shù)(arguments,callee,caller)使用方法進(jìn)行了介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助2014-01-01

