scroll-view 组件可以实现元素横、纵向滚动效果。要使用纵向滚动时,必须给 scroll-view 一个固定高度,同理横向滚动也是需要一个固定宽度。
一、竖向滚动
wxml代码如下:
<scroll-view class="scrollcss scrollcss-y" scroll-y>
<view>阿羡</view>
<view>时间段</view>
<view>打哈</view>
<view>最后一个</view>
</scroll-view>
.wxss代码如下
.scrollcss{
width: 200px;
height: 200px;
border: 1px solid royalblue;
background-color: royalblue;
margin: 50px auto;
}
.scrollcss-y view{
width: 200px;
height: 200px;
text-align: center;
line-height: 200px;
margin-bottom: 5px;
}
.scrollcss-y view:nth-child(1){
background-color: saddlebrown;
}
.scrollcss-y view:nth-child(2){
background-color: rgb(77, 139, 19);
}
.scrollcss-y view:nth-child(3){
background-color: rgb(222, 224, 64);
}
.scrollcss-y view:nth-child(4){
background-color: rgb(230, 43, 189);
}
二、横向滚动
wxml代码如下:
<scroll-view scroll-x class="swiper-nav" bindtap="swiperNav"
data-w="333" scroll-left='{{swiperNav.x}}'>
<text
class="item-nav {{swiperNav.i == index?'active':''}}"
wx:for="{{swiperNav.arr}}"
wx:key="this"
data-i="{{index}}"
>
{{item.txt}}
</text>
</scroll-view>
.wxss代码如下
.swiper-nav{
background-color: rgb(175, 228, 91);
/* 不换行 */
white-space: nowrap;
/* 去点击元素时的浅蓝色背景 */
/* -webkit-tap-highlight-color : transparent; */
}
.swiper-nav .item-nav{
position: relative;
padding: 32rpx;
color: #999;
font-size: 30rpx;
cursor: pointer;
display: inline-block
}
.swiper-nav .active{
color: #f43838
}
.swiper-nav .active::after{
content:'';
position: absolute;
left: 32rpx;
right: 32rpx;
bottom: 18rpx;
height:0;
border-bottom: 4rpx solid #f43838;
border-radius: 4rpx;
}
/**
* 页面的初始数据
*/
data: {
swiperNav:{
i:0,
x:0,
arr:[
{v:0,txt:"星期一"},
{ v: 1, txt: "星期二" },
{ v: 2, txt: "星期三" },
{ v: 3, txt: "星期四" },
{ v: 4, txt: "星期五" },
{ v: 5, txt: "星期六" }
]
}
},
// 导航栏切换
swiperNav(e){
console.log(e);
/*获取可视窗口宽度*/
var w=wx.getSystemInfoSync().windowWidth;
var leng=this.data.swiperNav.arr.length;
var i = e.target.dataset.i;
// 点击滑动
var disX = (i - 2) * w / leng;
if(i!=this.data.swiperNav.i){
this.setData({
'swiperNav.i':i
})
}
this.setData({
'swiperNav.x':disX
})
},
注意事项:flex布局使用失效问题
直接在<scroll-view></scroll-view>上使用flex时会失效,解决办法有两种:
①<scroll-view enable-flex="true"></scroll-view>添加上这个 enable-flex="true"属性
②在<scroll-view></scroll-view>下在再加一个容器,在该容器上设置flex