wx.pageScrollTo这个微信小程序的api功能如下:

简而言之就是实现页面滚动的。但是在实际应用当中显得有些鸡肋,为啥呢?使用中有明显页面有明显的抖动,这无疑是极不好的用户体验。我用的华为6x手机。

那么怎么解决这个问题?答案是选择利用scroll-view代替。上代码

 <scroll-view scroll-y style="height: 100%;position:absolute;" enable-back-to-top="true" bindscroll="memoryScrollTop" scroll-with-animation="true" scroll-top="{{scrollTop}}">
<view class='wrap' style='position:absolute;'>
<view id='general'>
<image src='../../images/timg.jpg'></image>
<view class='writing' wx:for="{{strategyGeneralObjArr}}" wx:key="{{index}}">
<view class='audio-box' wx:if="{{item.myAudio.length}}">
<view class='audio-box-logo' bindtap='playOrStopAudio'>
<view class='play-icon-box {{audioPlayStatus?"play-icon":"playing-icon"}}'> </view>
<audio id='myAudio' bindended="selfEndedPlay" bindtimeupdate="updatePlayTime" src='{{item.myAudio[0]}}' style='display:none;'></audio>
</view>
<view class='audio-box-progress'>
<view class='line-default'>
</view>
<view class='line-play-box'>
<view class='line-play' style='width:{{playPercenter}}'>
</view>
<view class='play-circle'></view>
</view> <view class='play-ing'> <text>{{updateTime}}</text>
<text>{{audioduration}}</text>
</view>
</view>
</view>
<view class='audio-title'>
{{item.title}}
</view>
<view class='audio-intro'>
{{item.desc}}
</view>
<view class='audio-tags skind'>
<block wx:for="{{item.label}}" wx:for-item="sonItem" wx:key="{{index}}">
<text>{{sonItem.name}}</text>
</block>
</view>
<view class='audio-address'>
<view class='audio-address-name'>
{{item.locationInfo.address}}
</view>
<view class='audio-address-distance'>
{{item.distance}}km
</view>
</view>
</view> </view>
<view id='intros'>
<block wx:for="{{strategyContentObjArr}}" wx:key="{{index}}">
<block wx:if="{{item.type==6}}">
<view class='trip-line unitItem {{"step"+index}}'>
<view class='titleLine mainTitle'>
<text class='left-line'></text>
<text class='titleLine-title'>{{item.data}}</text>
<text class='right-line'></text>
</view>
</view>
</block>
<block wx:if="{{item.type==7}}">
<view class='sonTitle'>
<text class='left-spot'></text>
<text class='sonTitle-title'>{{item.data}}</text>
<text class='right-spot'></text>
</view>
</block>
<block wx:if="{{item.type==1}}">
<view class='trip-line-instruct intro-writing'>
{{item.data}}
</view>
</block>
<block wx:if="{{item.type==2}}">
<view class='image'>
<image src='{{item.data}}' class='strategy-img'></image>
</view>
</block>
<block wx:if="{{item.type==4}}">
<view class='trip-mode-video video'>
<video wx:if='{{playOpenCode}}' id='myVideo' bindended="playSelfOver" bindpause="stopVideo" bindtimeupdate="memoryTime" src="{{item.data}}"> </video>
<view class='trip-mode-video-cover' wx:if='{{!playOpenCode}}'>
<image src='../../images/timg.jpg' class='cover'></image>
<image bindtap='playVideo' src='../../images/play.png' class='tip'></image>
</view>
</view>
</block>
</block>
</view>
<view class='blank'></view>
</view>
</scroll-view>

注意上述代码,因为含有很多变量,所以复制之后不保证管用。

注意上述scroll-view还有一层view这一层view是内容的二级父元素,而scroll-view是最顶级父元素,并且两者都需要使用绝对定位,还有scroll-view必须有一个固定高度。

这样就可以通过动态改变scroll-top="{{scrollTop}}" 来改变指定的高度了。

关于上述这种设置,以前接触并使用过h5移动端的滚动插件,比如BetterScroll 还有iscroll,在设置上面和上述一致。想到这点在看微信小程序或者里面也有类似的底层吧。

微信小程序wx.pageScrollTo的替代方案的更多相关文章

  1. 微信小程序wx.request接口

    微信小程序wx.request接口 wx.request是小程序客户端与服务器端交互的接口 HTTPS 请求 一个微信小程序,只能同时(同时不能大于5个)有5个网络请求 wx.request(OBJE ...

  2. 监控微信小程序wx.request请求失败

    在微信小程序里,与后台服务器交互的主要接口函数是wx.request(),用于发起 HTTPS 网络请求.其重要性不言而喻.然而,却经常遇到请求失败的问题,笔者特意谷歌"wx.request ...

  3. 微信小程序wx.showActionSheet调用客服信息功能

    微信小程序wx.showActionSheet调用客服消息功能 官方文档的代码: wx.showActionSheet({ itemList: ['A', 'B', 'C'], success (re ...

  4. 微信小程序 wx.uploadFile在安卓手机上面the same task is working问题解决

    微信小程序上传图片的时候,如果是多图片上传,一般都是直接用一个循环进行wx.uploadFile 这个在电脑上面测试与苹果手机上面都不会有什么问题 但当用安卓测试的时候,你会发现小程序会提示一个the ...

  5. 微信小程序wx.navigateTo层叠5次限制,特殊情况的建议

    小程序页面的实例使用栈的数据结构存储,栈内元素最多5个(换一种方式说,就是用户最多能点击5次返回),微信小程序能在栈中相对高层某个页面调用其他相对低层的页面实例的方法. 小程序三种页面跳转API 的区 ...

  6. 微信小程序wx.request请求用POST后台得不到传递数据

    微信小程序的wx.request请求,method设为POST并向后台传递数据,但从后台返回的信息来看后台并没有获得传递的数据 wx.request({              url: 'url' ...

  7. 坑:微信小程序wx.request和wx.uploadFile中传参数的区别

    微信小程序中通过组件<form>提交表单的时候,在js中通过e.detail.value得到所提交表单的json格式数据.一般提交表单我们都是通过wx.request请求,提交表单数据,通 ...

  8. 微信小程序wx.getLocation()获取经纬度及JavaScript SDK调用腾讯地图API获取某一类地址

    简介 腾讯位置服务为微信小程序提供了基础的标点能力.线和圆的绘制接口等地图组件和位置展示.地图选点等地图API位置服务能力支持,使得开发者可以自由地实现自己的微信小程序产品. 在此基础上,腾讯位置服务 ...

  9. 微信小程序 wx.request

    onLoad: function () { var that = this console.log('https://free-api.heweather.com/s6/weather?locatio ...

随机推荐

  1. yii学习笔记(3),自定义全局工具函数

    在平时开发是经常需要打印数据来调试 常见的打印方式有print_r和var_dump,但是这样打印出来格式很乱不好浏览 在打印函数前后加上<pre></pre>就可以将内容原样 ...

  2. 网站用户行为分析——Hadoop的安装与配置(单机和伪分布式)

    Hadoop安装方式 Hadoop的安装方式有三种,分别是单机模式,伪分布式模式,伪分布式模式,分布式模式. 单机模式:Hadoop默认模式为非分布式模式(本地模式),无需进行其他配置即可运行.非分布 ...

  3. 『Linux基础 - 1』计算机基础概念

    这篇笔记的知识点结构目录: 认识计算机: (1)什么是计算机; (2)计算机的发展过程 计算机的构成: (1) 计算机硬件系统; (2) 计算机软件系统 二进制: (1) 为什么用二进制 (2) 二进 ...

  4. fiddler请求报文的headers属性详解

    fiddler请求报文的headers属性详解 headers的属性包含以下几部分. (1)Cache头域 在Cache头域中,通常会出现以下属性. 1. Cache-Control 用来指定Resp ...

  5. 18CCPC网赛A 贪心

    Buy and Resell Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)To ...

  6. HyperLedger Fabric 1.4 kafka生产环境部署(11.1)

    11.1 Kafka模式简介       上一章介绍的Solo模式只存在一个排序(orderer)服务,是一种中心化结构,一旦排序(orderer)服务出现了问题,整个区块链网络将会崩溃,为了能在正式 ...

  7. PHP.50-TP框架商城应用实例-前台2-商品推荐

    商品推荐 {抢购,新品,精品,热卖}效果如下 1.在商品表增加促销价格与促销起始时间和结束时间三个字段,字段推荐楼层与排序在后面用到  注意:在增加datetime类型字段时,要添加默认值{datet ...

  8. JavaScript---设计模式之职责链模式

    概念 职责链模式是使多个对象都有机会处理请求,从而避免请求的发送者和接受者之间的耦合关系.将这个对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理他为止. 链中收到请求的对象要么亲自处理它,要 ...

  9. Android 模拟器 下载、编译及调试

    Android 模拟器源码下载 Android 模拟器源码的下载与 Android AOSP 源码库的下载过程类似,可以参考 Google 官方提供的 Android 源码下载文档 来了解这个过程. ...

  10. python操作字符串内容并重新输出

    今天在做一个函数的作业,题目如下: 编写一个函数实现大写转小写,小写变大写,并且转换为镜像字符串,并且将字符串变为镜像字符串. 例如:’A’变为’Z’,’b’变为’y 示范字符串: ”sdSdsfdA ...