微信小程序快速入门02(含案例)

🏡浩泽学编程个人主页
🔥 推荐专栏《深入浅出SpringBoot》《java项目分享》
《RabbitMQ》《Spring》《SpringMVC》

🛸学无止境,不骄不躁,知行合一

文章目录


前言

讲诉内容:页面导航、页面事件。


一、页面导航

页面导航指的是页面之间的相互跳转。例如,浏览器中实现页面导航的方式有如下两种:

  • < a > 链接
  • location.href

小程序实现页面导航的两种方式:

  • 声明式导航
    • 在页面上声明一个< navigator >导航组件
    • 通过点击< navigator >组件实现页面跳转
  • 编程式导航
    • 调用小程序的导航API,实现页面的跳转

1.声明式导航

导航到tabBar

  • tabBar 页面指的是被配置为 tabBar 的页面
  • 在使用< navigator >组件跳转到指定的tabBar 页面时,需要指定 ur 属性和 open-type 属性,其中:
    • url 表示要跳转的页面的地址,必须以/开头
    • open-type 表示跳转的方式,必须为 switchTab

示例代码如下:

html 复制代码
<navigator url="/pages/message/message" open-type="switchTab">导航到消息页面</navigator>

导航到非tabBar

  • 非 tabBar 页面指的是没有被配置为 tabBar 的页面
  • 在使用< navigator >组件跳转到普通的非 tabBar 页面时,则需要指定 url 属性和 open-type 属性,其中:
    • url 表示要跳转的页面的地址,必须以 / 开头
    • open-type 表示跳转的方式,必须为 navigate
  • 注意:为了简便,在导航到非 tabBar 页面时,open-type="navigate"属性可以省略

示例代码如下:

html 复制代码
<navigator url="/pages/list/list" open-type="navigate">导航到list页面</navigator>

后退导航

  • 如果要后退到上一页面或多级页面,则需要指定 open-type 属性和 delta 属性,其中:
    • open-type 的值必须是 navigateBack,表示要进行后退导航
    • delta 的值必须是数字,表示要后退的层级
  • 注意:为了简便,如果只是后退到上一页面,则可以省略 delta 属性,因为其默认值就是 1

示例代码如下:

html 复制代码
<navigator open-type="navigateBack" delta='1'>返回上一页</navigator>

导航传参

navigator组件的url 属性用来指定将要跳转到的页面的路径。同时,路径的后面还可以携带参数:

  • 参数与路径之间使用?分隔
  • 参数键与参数值用 =相连
  • 不同参数用 & 分隔

代码示例如下:

html 复制代码
<navigator url="/pages/list/list?name=zhangsan&age=20">跳转到list页面</navigator>

2.编程式导航

导航到tabBar页面

调用 wx.switchTab(Obiect obiect) 方法,可以跳转到 tabBar 页面。其中 Object 参数对象的属性列表如下:

示例如下:

html 复制代码
<button bindtap="gotoMessage">跳转到message页面</button>
js 复制代码
  gotoMessage(){
    wx.switchTab({
      url: '/pages/message/message',
    })
  }

导航到非tabBar页面

调用 wx.navigateTo(Object object)方法,可以跳转到非 tabBar 的页面。其中 Object 参数对象的属性列表如下:

示例如下:

html 复制代码
<button bindtap="gotoList">跳转到list页面</button>
js 复制代码
  gotoList(){
    wx.navigateTo({
      url: '/pages/list/list',
    })
  }

后退导航

调用 wx.navigateBack(Object object) 方法,可以返回上一页面或多级页面。其中 Object 参数对象可选的属性列表如下:

示例如下:

html 复制代码
<button bind:tap="gotoBack">后退</button>
js 复制代码
  gotoBack(){
    wx.navigateBack({
      delta:1
    })
  }

导航传参

html 复制代码
<button bind:tap="gotoList2">跳转到list页面</button>
js 复制代码
 gotoList2(){
    wx.navigateTo({
      url: '/pages/list/list?name=zs&age=20',
    })
  }

二、页面事件

1.下拉刷新

  • 下拉刷新是移动端的专有名词,指的是通过手指在屏幕上的下拉滑动操作,从而重新加载页面数据的行为。

  • 启用下拉刷新有两种方式:

    • 全局开启下拉刷新
      • 在app,json 的 window 节点中,将 enablePullDownRefresh 设置为 true
    • 局部开启下拉刷新
      • 在页面的json 配置文件中,将enablePullDownRefresh 设置为 true
  • 在实际开发中,推荐使用第2 种方式,为需要的页面单独开启下拉刷新的效果

  • 在全局或页面的json 配置文件中,通过 backgroundColor 和 backgroundTextStyle 来配置下拉刷新窗的样式,其中:

    • backgroundColor 用来配置下拉刷新窗口的背景颜色,仅支持16进制的颜色值
    • backgroundTextStyle 用来配置下拉刷 loading 的样式,仅支持 dark 和 light
  • 在页面的.js 文件中,通过onPullDownRefresh0 函数即可监听当前页面的下拉刷新事件

例子:

例如,在页面的 wxml中有如下的 UI结构,点击按钮可以让 count 值自增+1:

html 复制代码
<view>count值是:{{count}}</view>
<button bind:tap="addCount">+1</button>
js 复制代码
  addCount(){
    this.setData({
      count: this.data.count + 1,
    })
  }

在触发页面的下拉刷新事件的时候,如果要把 count 的值重置为0,示例代码如下:

js 复制代码
  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {
    this.setData({
      count: 0
    })
  }

当处理完下拉刷新后,下拉刷新的 loading 效果会一直显示,不会主动消失,所以需要手动隐藏下拉刷新的loading 效果。此时,调用wxstopPullDownRefresh0 可以停止当前页面的下拉刷新。示例代码如下:

js 复制代码
  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {
    this.setData({
      count: 0
    })
    wx.stopPullDownRefresh()
  }

2.上拉触底

  • 上拉触底是移动端的专有名词,通过手指在屏幕上的上拉滑动操作,从而加载更多数据的行为
  • 在页面的 js 文件中,通过 onReachBottom( 函数即可监听当前页面的上拉触底事件。
  • 上拉触底距离指的是触发上拉触底事件时,滚动条距离页面底部的距离
  • 可以在全局或页面的 .json 配置文件中,通过 onReachBottomDistance 属性来配置上拉触底的距离
  • 小程席默认的触底距离是 50px,在实际开发中,可以根据自己的需求修改这个默认值。

案例:

效果:

实现步骤:

上拉触底节流处理步骤:

html 复制代码
<view wx:for="{{colorList}}" wx:key="index" class="num-item" style="background-color: rgba({{item}});">{{item}}</view>
css 复制代码
.num-item{
  border: 1rpx solid #efefef;
  border-radius: 8rpx;
  line-height: 200rpx;
  margin: 15rpx;
  text-align: center;
  text-shadow: 0rpx 0rpx 5rpx #fff;
  box-shadow: 1rpx 1rpx 6rpx #aaa;
}
js 复制代码
data: {
    colorList: [],
    isloading: false
  },
getColors(){
    this.setData({
      isloading: true
    })
    //loading提示效果
    wx.showLoading({
      title: '数据加载中...',
    })
    wx.request({
      url: 'https://applet-base-api-t.itheima.net/api/color ',
      method: 'GET',
      success: ({data: res}) => {
        this.setData({
          colorList: [...this.data.colorList,...res.data]
        })
      },
      complete: ()=> {
        wx.hideLoading()
        this.setData({
          isloading: false
        })
      }
    })
  },
  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {
    if(this.data.isloading) return
    this.getColors()
  }

总结

以上就是微信小程序学习讲解。

相关推荐
雷神乐乐13 分钟前
File.separator与File.separatorChar的区别
java·路径分隔符
小刘|18 分钟前
《Java 实现希尔排序:原理剖析与代码详解》
java·算法·排序算法
qq229511650236 分钟前
微信小程序的汽车维修预约管理系统
微信小程序·小程序·汽车
逊嘘37 分钟前
【Java语言】抽象类与接口
java·开发语言·jvm
morris13144 分钟前
【SpringBoot】Xss的常见攻击方式与防御手段
java·spring boot·xss·csp
我要洋人死1 小时前
导航栏及下拉菜单的实现
前端·css·css3
科技探秘人1 小时前
Chrome与火狐哪个浏览器的隐私追踪功能更好
前端·chrome
科技探秘人1 小时前
Chrome与傲游浏览器性能与功能的深度对比
前端·chrome
JerryXZR1 小时前
前端开发中ES6的技术细节二
前端·javascript·es6
七星静香1 小时前
laravel chunkById 分块查询 使用时的问题
java·前端·laravel