小编 / 达叔小生

小程序开发基础-scroll-view 可滚动视图区域

这里只展示纵向滚动,横向同理就不用说明了,可自己尝试,横向滚动属性为scroll-x,把纵向滚动改为横向滚动即可。

scroll-view视图组件

scroll-yscroll-view的属性,scroll-y类型为Boolean,默认值为false,表示允许纵向滚动,scroll-y="true"允许纵向滚动

bindscrolltoupperscroll-view的属性,bindscrolltoupper类型为EventHandle,表示滚动到顶部/左边,会触发scrolltoupper事件,顶部/左边,是因为滚动视图可以横向滚动和纵向滚动,bindscrolltoupper="upper"定义绑定事件,在逻辑代码中编写,滚动到顶部,触发scrolltoupper事件。

bindscrolltolowerscroll-view属性,与上述bindscrolltoupper同理,bindscrolltolower的类型也是EventHandlebindscrolltolower表示滚动到底部/右边,会触发scrolltolower事件,bindscrolltolower="lower"表示绑定事件lower,会触发scrolltolower事件。

bindscrollscroll-view属性,类型是EventHandle,表示滚动触发,与上述bindscrolltoupper属性和bindscrolltolower属性范围广,bindscroll滚动触发,event.detail = {scrollLeft, scrollTop, scrollHeight, scrollWidth, deltaX, deltaY}

在定义scroll-view时,要给它一个固定的高度,通过wxss也可以内部样式,给设置个height属性,如style="height:200px;"

scroll-into-viewscroll-view的属性,类型为String类型,表示值应为某子元素的id,甚至哪个方向可滚动,则在哪个方向滚动到该元素。代码中scroll-into-view="{{toView}}"toView的值到js中的data中。

scroll-topscroll-view的属性,类型为Number类型,表示值应为设置竖向滚动条位置,同时横向有个scroll-left属性。

  1. <!-- index.wxml -->
  2. <scroll-view scroll-y="true" style="height: 200px;" bindscrolltoupper="upper" bindscrolltolower="lower" bindscroll="scroll" scroll-into-view="{{toView}}" scroll-top="{{scrollTop}}">
  3. ...
  4. </scroll-view>

给这个视图组件加几个视图,一个视图高度以给定"height:200px"

  1. <view id="green" class="scroll-view-item bc_green"></view>
  2. <view id="red" class="scroll-view-item bc_red"></view>
  3. <view id="yellow" class="scroll-view-item bc_yellow"></view>
  4. <view id="blue" class="scroll-view-item bc_blue"></view>

再给两个按钮,一个是点击效果为,下一个视图,如同翻页的效果,点击按钮切换到下一个view,另一个按钮的点击效果为,设置滚动条位置实现画面滚动,就是下移或上移等。

click me to scroll into view为点击我跳转到下一个view视图

click me to scroll为点击我进行滚动

  1. <!-- index.wxml -->
  2. <scroll-view scroll-y="true" style="height: 200px;" bindscrolltoupper="upper" bindscrolltolower="lower" bindscroll="scroll" scroll-into-view="{{toView}}" scroll-top="{{scrollTop}}">
  3. <view id="green" class="scroll-view-item bc_green"></view>
  4. <view id="red" class="scroll-view-item bc_red"></view>
  5. <view id="yellow" class="scroll-view-item bc_yellow"></view>
  6. <view id="blue" class="scroll-view-item bc_blue"></view>
  7. </scroll-view>
  8. <view class="btn-area">
  9. <button size="mini" bindtap="tap">click me to scroll into view </button>
  10. <button size="mini" bindtap="tapMove">click me to scroll</button>
  11. </view>

scroll-view属性表格

属性名 说明
scroll-x 表示允许横向滚动
scroll-y 表示允许纵向滚动
upper-threshold 表示距顶部或者左边多远时(单位为px),触发scrolltoupper事件
lower-threshold 表示距底部或者右边多远时时(单位为px),触发scrolltolower事件
scroll-top 表示设置竖向滚动条位置
scroll-left 表示设置横向滚动条位置
scroll-into-view 表示指应为某子元素idid不能以数字开头),设置哪个方向可滚动,则在哪个方向滚动到该元素
scroll-with-animation 表示在设置滚动条位置时使用动画过渡
bindscrolltoupper 表示滚动到顶部或左边,会触发scrolltoupper事件
bindscrolltolower 表示滚动到底部或右边,会触发scrolltolower事件
bindscroll 表示滚动时触发
enable-back-to-top 表示iOS点击顶部状态栏、安卓双击标题栏时,滚动条返回顶部,只支持竖向

class="scroll-view-item bc_green"中,在wxss样式定义,高度为200px,如果没有就不会出现,你可以自己试试,margin属性定义,四周都是10px,其它为背景颜色而已。

  1. /* index.wxss */
  2. /* .scroll-view_H{
  3. white-space: nowrap;
  4. } */
  5. .scroll-view-item{
  6. height: 200px;
  7. }
  8. /* .scroll-view-item_H{
  9. display: inline-block;
  10. width: 100%;
  11. height: 200px;
  12. } */
  13. .btn-area button{
  14. margin: 10px;
  15. }
  16. .bc_green {
  17. background-color: green;
  18. }
  19. .bc_red {
  20. background-color: red;
  21. }
  22. .bc_yellow {
  23. background-color: yellow;
  24. }
  25. .bc_blue {
  26. background-color: blue;
  27. }

逻辑index.jsupper为滚动条滚到顶部的时候触发,lower为滚动条滚到底部的时候触发,scroll为滚动条滚动后触发,tap为点击按钮切换到下一个viewtapMove为通过设置滚动条位置实现画面滚动。

  1. // index.js
  2. var order = ['red', 'yellow', 'blue', 'green', 'red']
  3. Page({
  4. data: {
  5. toView: 'green',
  6. scrollTop: 100,
  7. scrollLeft: 0
  8. },
  9. // 滚动条滚到顶部的时候触发
  10. upper: function(e) {
  11. console.log(e)
  12. },
  13. // 滚动条滚到底部的时候触发
  14. lower: function(e) {
  15. console.log(e)
  16. },
  17. // 滚动条滚动后触发
  18. scroll: function(e) {
  19. console.log(e)
  20. },
  21. // 点击按钮切换到下一个view
  22. tap: function(e) {
  23. for (var i = 0; i < order.length; ++i) {
  24. if (order[i] === this.data.toView) {
  25. this.setData({
  26. toView: order[i + 1]
  27. })
  28. break
  29. }
  30. }
  31. },
  32. //通过设置滚动条位置实现画面滚动
  33. tapMove: function(e) {
  34. this.setData({
  35. scrollTop: this.data.scrollTop + 10
  36. })
  37. }
  38. })

toView: 'green',为scroll-into-view显示在green绿色的地方,在index.wxml中的scroll-into-view="{{toView}}"scrollTop: 100,为scroll-top="{{scrollTop}}"在显示时就是绿色的占一半,红色的占一半,因为总的才200px嘛。

scroll-top的用途说明一下,为甚至竖向滚动条位置。scroll-into-view为滚动到该元素,简要的说。总的来说,值应为某子元素idid不能以数字开头)。设置哪个方向可滚动,则在哪个方向滚动到该元素,可知道要id,所以在index.wxml中有了<view id="green" class="scroll-view-item bc_green"></view>这个描述,里面的id="green"

这样就可以理解以下代码:

  1. data: {
  2. toView: 'green',
  3. scrollTop: 100,
  4. scrollLeft: 0
  5. },
  6. // scrollLeft:是用来横向的嘛
  1. var order = ['red', 'yellow', 'blue', 'green', 'red']
  2. // 点击按钮切换到下一个view
  3. tap: function(e) {
  4. for (var i = 0; i < order.length; ++i) {
  5. if (order[i] === this.data.toView) {
  6. this.setData({
  7. toView: order[i + 1]
  8. })
  9. break
  10. }
  11. }
  12. },

重要事项:

开源github分享

Wechat_small_program_Share

微信小程序分享

小程序开发基础-scroll-view 可滚动视图区域的更多相关文章

  1. 小程序开发基础-swiper 滑块视图容器

    小编 / 达叔小生 参考官方文档:https://developers.weixin.qq.com/miniprogram/dev/component/ 小程序开发基础-swiper 滑块视图容器 根 ...

  2. 微信小程序开发基础

    前言: 微信小程序开入入门,如果你有html+css+javascript的基础,那么你就很快地上手掌握的.下面提供微信小程序官方地址:https://developers.weixin.qq.com ...

  3. 小程序开发-基础组件icon/text/progress入门

    小程序的基础组件--基础内容 基础内容分为三大组件: 1. icon--图标 index.wxml <view class="group"> <block wx: ...

  4. 小程序开发基础-view视图容器

    view 视图容器. // wxml <view class="section"> <view class="section__title"& ...

  5. 微信小程序开发基础知识总结

    微信小程序在无论在功能.文档及相关支持方面,都是优于前面几种微信账号类型,它提供了很多原生程序才有的接口,使得我们的小程序在很多方面突破H5页面应用的限制,更加接近原生程序的功能,因此微信小程序具有很 ...

  6. 微信小程序开发教程(八)视图层——.wxml详解

    框架的视图层由WXMKL(WeiXin Markup language)与WXSS(WeiXin Style Sheet)编写,由组件进行展示. 对于微信小程序而言,视图层就是所有.wxml文件与.w ...

  7. 微信小程序开发---视图层(View)

    WXML WXML能力: 数据绑定 列表渲染 条件渲染 模板 事件 数据绑定 数据绑定使用 Mustache 语法(双大括号)将变量包起来,可作用于内容,组件属性(需要在双引号之内),控制属性(需要在 ...

  8. 微信小程序开发教程(九)视图层——.wxss详解

    WXSS是一套样式语言,用于描述WXML的组件样式. 官方文档表示,WXSS的选择器目前支持(“.class”.“#id”.“elemnt”.“element,element”.“::after”.“ ...

  9. 【微信小程序】基础组件--view text image

    组件的通用属性: id class style hidden bind* catch* data-* view 小程序基础组件,基本等于最常用组件,类似于HTML中的div.view用于构建页面骨架, ...

随机推荐

  1. c#dev gridview 设置隔行换色等

    1:禁止gridview编辑 2:隔行换色 介绍一些常用的gridcontrol设置. 1.设置隔行变色.首先设置显示隔行变色,步骤:OptionsView-->EnableAppearance ...

  2. debian9使用国内源安装docker以及一些使用方法

    debian9使用国内源安装docker以及一些使用方法   首先, 我的环境是debian, 容器是centos debian 扔源 # deb-src [arch=amd64] https://m ...

  3. docker不能上传镜像到自己网站的仓库

    错误提示如下: WARNING! Using --password via the CLI is insecure. Use --password-stdin. Error response from ...

  4. SpringBoot图片上传

    毕设终于写到头像上传了,本来想用Vue写来着,但是一直不顺利,还是对Vue用的不太熟.所以就用jquery写了. 首先添加以下标签 <img id="avatarPreview&quo ...

  5. laravel-debugbar安装

    第一步:找到debugbar扩展包 扩展包的链接:https://packagist.org/packages/barryvdh/laravel-debugbar 第二步:安装 我测试的环境larav ...

  6. react-01

    比较了半天VUE.Angular.React,最终选择React,下面从几个例子开始React的学习,先从单个的index.html,引用react.js开始 一.最简单的纯JS的代码 <!DO ...

  7. Linux 网络编程 入门-常用函数

    网络连接无外乎服务器和客户端两方面的编程. 对于服务器大致的流程是:1---调用socket函数创建套接字 2---调用bind函数分配IP地址和端口号 3---调用listsen函数将套接字转为可接 ...

  8. cookie存储

    cookie就是用来存储数据的 cookie先分装函数 这是用来存数据的函数 function setCookie(name,value,iDay){ if(iDay){ var oDate = ne ...

  9. python中os.path 与sys.path

    看别人写的代码,会发现两个和路径设置有关的模块 os 和sys.我对这两个模块也不是特别了解.只是记录一下自己看到的,学到的. python 中我们会使用这两个模块和文件路径, 创建文件 之类的 操作 ...

  10. linu输出重定向

    1.tee命令 ls | tee filename #若出现Permission Denied使用下面 ls | sudo tee filename #清空filename后重写 ls | sudo ...