菜单

微信小程序scroll-view实现字幕滚动

2019年5月25日 - jQuery

正文实例为我们享受了微信小程序scroll-view完结字幕滚动的求实代码,供大家仿照效法,具体内容如下

微信小程序scroll-view组件达成滚动动画,小程序scroll-view

正文实例为大家享用了scroll-view组件实现索引列表滚动动画效果,供我们参考,具体内容如下

效果图

金镶玉裹福禄双全原理

接纳scroll-view的scroll-into-view属性进行稳固;
应用scroll-view的scroll-with-animation属性达成滚动动画过度。

WXML

<view class="right-nav">
  <view bindtap="getCurrentCode" class="{{chooseIndex == index ? '.city-list-active' : ''}}" wx:for="{{cityList}}" style="height:{{codeHeight}}px" data-code="{{item.code}}" data-index="{{index}}">
  {{item.code}}
  </view>
</view>

<view class="city-layer {{isShowLayer ? '' : 'layer-hide'}}">
 {{codeY}}
</view>

<view class="current-choose-city">当前选择机场:{{chooseCity}}</view>
<scroll-view class="city-scroll" scroll-y="true" scroll-into-view="{{codeY}}" scroll-with-animation="true" style="height:{{cityHeight}}px" bindscroll="scroll">
  <view class="city-box" wx:for="{{cityList}}" wx:key="{{item.code}}">
    <view class="city-code" id="{{item.code}}">{{item.code}}</view>
    <view class="city-list" wx:for="{{item.cityList}}" wx:for-item="city" bindtap="getChooseCity" data-city="{{city}}"> 
       {{city}} 
    </view> 
  </view>
</scroll-view>

WXSS

.current-choose-city{
 position: fixed;
 width: 100%;
 height: 50px;
 line-height: 50px;
 padding: 0 10px;
 top: 0;
 left: 0;
 background-color: #fff;
 z-index: 10;
}
.right-nav{
 width: 30px;
 color: #888;
 text-align: center;
 position: fixed;
 bottom: 0;
 right: 0;
 background-color: rgb(200, 200, 200);
 z-index: 9;
}
.city-scroll{padding-top: 50px;}
.city-code{
 background-color: #f7f7f7;
}
.city-list,.city-code{
 height: 39px;
 line-height: 40px;
 padding: 0 30px 0 10px;
 overflow: hidden;
 border-bottom: 1px solid #c8c7cc;
}
.city-list-active{color:#007aff;}

/*提示点击的字母 */
.city-layer{
 width: 70px;
 height: 70px;
 line-height: 70px;
 text-align: center;
 border-radius: 50%;
 color: #fff;
 background-color: rgba(0, 0, 0, .7);
 position: fixed;
 top: calc(50% - 35px);
 left:calc(50% - 35px);
 z-index: 11;
}
.layer-hide{display: none;}

JS

var city_list = require('./city.js');

Page({
 data: {
  cityList: city_list.city,
  chooseCity: '您还未选择机场!',
  isShowLayer: false,
  chooseIndex: 0,
  codeY: 'A',
  codeHeight: null,
  cityHeight:null
 },
 onLoad (options) {
  var windowHeight = wx.getSystemInfoSync().windowHeight;
  this.setData({ 
   codeHeight: (windowHeight - 50) / this.data.cityList.length,
   cityHeight: windowHeight - 50,
  });
 },
 getCurrentCode(e){
  var self = this;
  this.setData({ 
   codeY: e.target.dataset.code,
   chooseIndex: e.target.dataset.index,
   isShowLayer: true 
  })
  setTimeout(() => {
   self.setData({ isShowLayer: false })
  },500);
 },
 getChooseCity(e){
  this.setData({ chooseCity: e.target.dataset.city });
 }
})

对比

微信小程序—-全国飞机场索引列表(MUI索引列表)

相比结果总括

DEMO下载

以上正是本文的全体内容,希望对大家的就学抱有协助,也冀望大家多多支持帮客之家。

http://www.bkjia.com/Javascript/1299490.htmlwww.bkjia.comtruehttp://www.bkjia.com/Javascript/1299490.htmlTechArticle微信小程序scroll-view组件实现滚动动画,小程序scroll-view
本文实例为大家大快朵颐了scroll-view组件实现索引列表滚动动画效果,供我们参照他事他说加以考查,具体…

需求:

贯彻框内的文字自下而上的自发性循环滚动。

缓慢解决方案:

通过调控滑动条来产生字幕滚动,通过setinterval完毕字幕循环滚动。

wxml:

<scroll-view class="container" scroll-y="true" bindscroll="scroll" scroll-top="{{scrollTop}}">
 <view class='list'>
  <view class='blank'></view>
  <view>
   <text class="txt-light">09:08</text> 很多人的一生,基本都是自己跟别人较劲,比如别人对自己的期待,比如把别人看得太重把自己看得太轻。其实一个人最应该考虑的问题是,自己如何与自己相处,比如人去楼空的时候如何照顾好自己的孤独,比如夜深人静的时候如何跟心灵沟通。自己跟自己能和谐共处,自己跟别人就能相安无事。
  </view>
  <view>
   <text class="txt-light">19:08</text> 平和是待人处事的一种态度,也是做人酌一种美德。平和既是一种修养,又是一种工作方法。平和的人,从不被忙碌所萦绕,闲时吃紧,忙里悠闲。待人不严,教人勿高。宽严得宜,分寸得体。身心自在,能享受生活之乐趣。平和的人生,是和谐的人生,健康的人生。
  </view>
  <view class='blank'></view>
 </view>
</scroll-view>

wxss:

.container {
 background-color: #FAEBD7;
 height: 150rpx;
}

.txt-light {
 color: #acadbe;
}

.blank {
 height: 150rpx;
}

js

Page({

 /**
  * 页面的初始数据
  */
 data: {
  scrollTop:0
 },

 /**
  * 生命周期函数--监听页面加载
  */
 onLoad: function (options) {

 },

 /**
  * 生命周期函数--监听页面初次渲染完成
  */
 onReady: function () {

 },

 /**
  * 生命周期函数--监听页面显示
  */
 onShow: function () {
  // 获取scroll-view的节点信息
  //创建节点选择器
  var query = wx.createSelectorQuery();
  query.select('.container').boundingClientRect()
  query.select('.list').boundingClientRect()
  query.exec((res) => {
   var containerHeight = res[0].height;
   var listHeight = res[1].height;

   // 滚动条的高度增加
   var interval = setInterval(() => {
    if (this.data.scrollTop < listHeight - containerHeight) {
     this.setData({
      scrollTop: this.data.scrollTop + 10
     })
    } else {
     // clearInterval(interval);
     this.setData({
      scrollTop: 0
     })
    }
   }, 1000)
  })

 },
 scroll: function () {
  // 获取scroll-view的节点信息
  //创建节点选择器
  var query = wx.createSelectorQuery();
  query.select('.list').boundingClientRect()
  query.exec((res) => {
   this.setData({
    scrollTop: -(res[0].top)
   })
   // console.log(res);
  })
 }
})

tips:本次字幕滚动,就能够自行滚动,也可拖动。

如上便是本文的全体内容,希望对我们的求学抱有协理,也意在大家多多援助脚本之家。

你或然感兴趣的篇章:

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图