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

在这里插入图片描述

🏡浩泽学编程:个人主页

 🔥 推荐专栏:《深入浅出SpringBoot》《java项目分享》
              《RabbitMQ》《Spring》《SpringMVC》

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

文章目录

  • 前言
  • 一、页面导航
    • 1.声明式导航
    • 2.编程式导航
  • 二、页面事件
    • 1.下拉刷新
    • 2.上拉触底
  • 总结


前言

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


一、页面导航

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

  • < a > 链接
  • location.href

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

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

1.声明式导航

导航到tabBar

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

示例代码如下:

<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"属性可以省略

示例代码如下:

<navigator url="/pages/list/list" open-type="navigate">导航到list页面</navigator>

后退导航

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

示例代码如下:

<navigator open-type="navigateBack" delta='1'>返回上一页</navigator>

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

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

代码示例如下:

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

2.编程式导航

导航到tabBar页面
调用 wx.switchTab(Obiect obiect) 方法,可以跳转到 tabBar 页面。其中 Object 参数对象的属性列表如下:
在这里插入图片描述
示例如下:

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

导航到非tabBar页面
调用 wx.navigateTo(Object object)方法,可以跳转到非 tabBar 的页面。其中 Object 参数对象的属性列表如下:
在这里插入图片描述
示例如下:

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

后退导航
调用 wx.navigateBack(Object object) 方法,可以返回上一页面或多级页面。其中 Object 参数对象可选的属性列表如下:
在这里插入图片描述
示例如下:

<button bind:tap="gotoBack">后退</button>
  gotoBack(){wx.navigateBack({delta:1})}

导航传参

<button bind:tap="gotoList2">跳转到list页面</button>
 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:

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

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

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

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

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

2.上拉触底

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

案例:
效果:
在这里插入图片描述
实现步骤:
在这里插入图片描述
上拉触底节流处理步骤:
在这里插入图片描述

<view wx:for="{{colorList}}" wx:key="index" class="num-item" style="background-color: rgba({{item}});">{{item}}</view>
.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;
}
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) returnthis.getColors()}

总结

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/618331.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

互联网资讯精选:科技爱好者周刊 | 开源日报 No.145

ruanyf/weekly Stars: 37.4k License: NOASSERTION 记录每周值得分享的科技内容&#xff0c;提供大量就业信息。欢迎投稿、推荐或自荐文章/软件/资源&#xff0c;并可通过多种方式进行搜索。 提供丰富的科技内容每周更新可以提交工作/实习岗位支持投稿和推荐功能 GyulyVGC/…

bootloader学习笔记及SD卡启动盘制作

Bootloader介绍 在操作系统运行之前运行的一小段代码&#xff0c;用于将软硬件环境初始化到一个合适的状态&#xff0c;为操作系统的加载和运行做准备&#xff08;其本身不是操作系统&#xff09; Bootloader基本功能 1、初始化软硬件环境 2、引导加载linux内核 3、给linux…

一个无敌的 Python 文件系统监控库

在软件开发和系统管理领域&#xff0c;经常需要监控文件和目录的变化&#xff0c;以便在文件被创建、修改或删除时触发相应的操作。Python Watchdog是一个强大的Python库&#xff0c;它提供了简单而灵活的方式来监控文件系统的变化。本文将详细介绍Python Watchdog的用法和功能…

旅游数据可视化大屏:一屏掌控,畅游数据之海

随着旅游业的蓬勃发展&#xff0c;如何有效地管理和分析旅游数据成为行业关注的焦点。旅游数据可视化大屏作为一种新兴的技术手段&#xff0c;为旅游业带来了前所未有的机遇和挑战。 旅游数据可视化大屏集成了丰富的数据资源&#xff0c;通过直观的图表、图像和交互界面&#x…

慢 SQL 的优化思路

分析慢 SQL 如何定位慢 SQL 呢&#xff1f; 可以通过 slow log 来查看慢SQL&#xff0c;默认的情况下&#xff0c;MySQL 数据库是不开启慢查询日志&#xff08;slow query log&#xff09;。所以我们需要手动把它打开。 查看下慢查询日志配置&#xff0c;我们可以使用 show …

C++力扣题目654--最大二叉树

给定一个不重复的整数数组 nums 。 最大二叉树 可以用下面的算法从 nums 递归地构建: 创建一个根节点&#xff0c;其值为 nums 中的最大值。递归地在最大值 左边 的 子数组前缀上 构建左子树。递归地在最大值 右边 的 子数组后缀上 构建右子树。 返回 nums 构建的 最大二叉树…

【Spring Boot 3】【数据源】自定义JPA数据源

【Spring Boot 3】【数据源】自定义JPA数据源 背景介绍开发环境开发步骤及源码工程目录结构总结背景 软件开发是一门实践性科学,对大多数人来说,学习一种新技术不是一开始就去深究其原理,而是先从做出一个可工作的DEMO入手。但在我个人学习和工作经历中,每次学习新技术总是…

使用DevEco Studio导入Har模块,提示“Module Check Failed”—鸿蒙开发已解决

文章目录 项目场景:问题描述原因分析:解决方案:此Bug解决方案总结总结心得:寄语项目场景: 最近也是遇到了这个问题,看到网上也有人在询问这个问题,本文总结了自己和其他人的解决经验,解决了导入Har模块,提示“Module Check Failed" 的问题。 使用DevEco Studio…

7、防写一个shell 命令解释器

1、代码部分 #include <stdio.h> #include <stdlib.h> #include <string.h>#define MAX_INPUT_LENGTH 100void parse_command(char *command) {// 用于存储解析后的命令和参数char cmd[MAX_INPUT_LENGTH];char args[MAX_INPUT_LENGTH];// 将输入的命令拷贝到…

微信商家转账到零钱,既能单笔又能批量,支持多商户管理

大家好&#xff0c;我是小悟 微信商家转账到零钱的功能大家应该都熟悉吧&#xff0c;为了满足商家向用户微信零钱转账的需求&#xff0c;微信支付推出【商家转账到零钱】服务&#xff0c;方便商户可以一次向单个或多个用户的微信零钱转账。 商家转账到零钱为商户提供了简便、…

计算机毕业设计----SSH高校科研管理系统平台

项目介绍 本项目包含超级管理员、管理员、教师三种角色&#xff1b; 超级管理员角色包含以下功能&#xff1a; 登录,教师管理,管理员管理等功能。 管理员角色包含以下功能&#xff1a; 登录,专业参赛奖项管理,科技论文发表管理,出版专业著作管理,科研项目立项管理,科研项目结…

MySQL从0到1全教程【2】SQL语言的通用语法及分类

1 SQL语言的通用语法格式 无论是那种数据库的产品&#xff0c;SQL语法都是通用的。 SQL语句可以单行编写也可以多行编写&#xff0c;以分号结尾。SQL语句可以使用空格或者缩进的方式来增强语句的可读性&#xff0c;空格和缩进的数量没有限制。MySQL数据库的SQL语句是不区分大…

常常放生,与佛心更相契

弘一法师曾说&#xff1a;“世上最好的放生&#xff0c;就是放过自己。”天地与我并生&#xff0c;万物与我为一&#xff0c;每一个众生最宝贵的是自己的生命。而人自称万物之灵&#xff0c;就应当有爱护万物、保护万物的责任心&#xff0c;心中要有慈悲和恻隐之心&#xff0c;…

金蝶云星空和吉客云单据接口对接

金蝶云星空和吉客云单据接口对接 对接系统&#xff1a;吉客云 吉客云是基于“网店管家”十五年电商ERP行业和技术积累基础上顺应产业发展需求&#xff0c;重新定位、全新设计推出的换代产品&#xff0c;从业务数字化和组织数字化两个方向出发&#xff0c;以构建流程的闭环为依归…

什么是分治法算法思想?

一、问题 分治与递归就像⼀对孪⽣兄弟&#xff0c;在设计算法时经常是同时应⽤的&#xff0c;递归算法⽐较好理解&#xff0c;那么什么是分治法算法思想呢&#xff1f; 二、解答 分治法算法的设计思想就是将⼀个难以直接解决的⼤问题&#xff0c;分割成⼀些规模较⼩的相同问题…

高级JavaScript。如何用JavaScript手撸一个富文本编辑器?

要素过多建议收藏 - 富文本编辑 基本的技术就是在空白 HTML 文件中嵌入一个 iframe 。通过 designMode 属性&#xff0c;可以将这个空白文档变成可以编辑的&#xff0c;实际编辑的则是 <body> 元素 的 HTML 。 designMode 属性有两个可能的值&#xff1a; "…

高级RAG(六): 句子-窗口检索

之前我们介绍了LlamaIndex的从小到大的检索 的检索方法&#xff0c;今天我们再来介绍llamaindex的另外一种高级检索方法: 句子-窗口检索(Sentence Window Retrieval)&#xff0c;在开始介绍之前让我们先回顾一下基本的RAG检索的流程&#xff0c;如下图所示&#xff1a; 在执行基…

Fedora 36 正式发布稳定的Linux桌面版本

Fedora 36今天发布&#xff0c;这是最近一段时间以来又一个强大、前沿而又稳定可靠的Linux发行版本&#xff0c;除了这些特点外&#xff0c;Fedora 36还在原先的基础上增加了新的功能和细节打磨。 Fedora 36使用GNOME 42作为其默认的Fedora工作站桌面环境。 OpenSSL 3.0&#x…

Linux应用编程:定时器

目录 定时任务sleep定时器setitimersetitimersample POSIX Timer创建定时器timer_create启动定时器timer_settime剩余时间timer_gettime定时器超限timer_getoverrun删除定时器timer_deletesample1:信号方式sample2:线程形式 定时任务sleep 嵌入式Linux应用编程中&#xff0c;通…

Wargames与bash知识16

Wargames与bash知识16 Bandit24 关卡提示&#xff1a; 一个守护进程正在端口30002上侦听&#xff0c;如果给定bandit24的密码和一个4位数的密码&#xff0c;它将为您提供bandit25的密码。没有办法检索pincode&#xff0c;除非遍历所有10000个组合&#xff0c;称为暴力强制。您…