小程序 --- 点击放大功能、获取位置信息、文字样式省略、页面跳转(navigateTo)

1. 点击放大功能的实现

需求: 点击轮播图中的图片会实现放大预览的功能。首先有轮播图的样式如下
在这里插入图片描述

<!-- pages/goods_detail/index.wxml -->
<!-- 轮播图 -->
<view class="detail_swiper"><swiperautoplaycircularindicator-dots><swiper-itemwx:for="{{goodsObj.pics}}"wx:key="pics_id"bindtap="handlePreviewImage"data-url="{{item.pics_mid}}"><image mode="widthFix" src="{{item.pics_mid}}"></image></swiper-item></swiper>
</view>

上面给轮播图绑定了一个点击事件 handlePreviewImage,下面在JS文件中监听这个事件的点击

// pages/goods_detail/index.js
Page({// 点击轮播图 放大预览handlePreviewImage(e) {const { url: current } = e.currentTarget.datasetconst urls = this.GoodsInfo.pics.map(v => v.pics_mid)wx.previewImage({current,urls: urls})}
})

使用了微信提供的previreImage方法,current是点击进去的图片url(String类型),urls是预览的图片组的url数组(数组元素,里面是String类型)

2. 底部工具栏的封装

效果如下
在这里插入图片描述

2.1 基础知识补充 - navigator

导航组件: 类似超链接标签

属性名类型默认值说明
targetStringself在哪个目标上发生跳转,漠然当前小程序,可选值self/miniProgram
urlString当前小程序内的跳转链接
opentypeStringnavigate跳转方式

open-type有效值

说明
navigate保留当前页面,跳转到页面内的某个页面,但不能跳到tabbar页面
redirect关闭当前页面,跳转到应用内的某个页面,但是不允许跳转到tabbar页面
switchTab跳转到tabBar页面,并关闭其他所有非tabBar页面
reLaunch关闭所有页面,打开到应用内的某个页面
navigateBack关闭当前页面,返回上一页或多级页面,可通过getCurrentPages()获取当前的页面栈,决定需要返回
.exit退出小程序,target="miniProgram"时生效

2.2 页面骨架

<!-- pages/goods_detail/index.html -->
<!-- 底部工具栏 -->
<view class="btm-bool"><view class="bool_item"><view class="iconfont icon-kefu"></view><view>客服</view><button open-type="contact"></button></view><view class="bool_item"><view class="iconfont icon-weibiaoti-_huabenfuben"></view><view>分享</view><button open-type="share"></button></view><navigatoropen-type="switchTab"url="/pages/cart/index"class="tool_item"><view class="iconfont icon-che"></view><view>购物车</view></navigator><view class="tool_item btn_cart">加入购物车</view><view class="tool_item btn_buy">立即购买</view>
</view>

2.3 样式

/* 底部工具栏 */
.footer_tool{position: fixed;left: 0;bootom: 0;width: 100%;height: 90rpx;background-color: #fff;display: flex;border-top: 1rpx solid #ccc;
} .footer_tool .all_chk_wrap {flex: 2;display: flex;justify-content: center;align-items: center;
}.footer_tool .total_price_wrap {flex: 5;text-align: right;padding-right: 15rpx;
}.footer_tool .total_price_wrap .total_price .total_price_text {color: var(--themeColor);font-size: 34rpx;font-weight: 600;
}
.footer_tool .order_pay_wrap {flex: 3;display: flex;justify-content: center;align-items: center;background-color: var(--themeColor);color: white;font-weight: 600;font-size: 32rpx;
}

以上使用了flex布局,值得说明的是: 使用justify-content: center + align-items: center可以很方便的实现盒子内内容的垂直居中对齐

3. 获取收货地址

3.1展示

在这里插入图片描述
首先有一个按钮,点击之后会获取权限
在这里插入图片描述
若以前拒绝过.则会条转到获取权限的界面
在这里插入图片描述

3.2 实现

需求: 有时候某些需求需要用户授权, 而这些权限用户之前可能拒绝过.这就需要用到微信提供的API(openSetting),来进行重新授权

栗子: 在购物车中,当用户在获取收获地址时(chooseAddress), 有可能先拒绝过获取地址的提示.获取信息可以使用(getSetting)API获取.未授权时调用openSetting,授权了调用chooseAddress, 具体代码如下:

<!-- pages/cart/index.wxml -->
<view class="receive_address_row"><view class="address_btn"><button bindtap="handleChooseAddress" plain type="primary">获取收货地址</button></view>
</view>

上面实现了收货地址的一个按钮,下面通过JS和微信提供的API来实现收货地址的逻辑:

  • 首先获取状态,判断是否运行访问地址
    • 否: 调用获取权限的API
    • 是: 不做处理
  • 接下来通过获取地址的api来获取用户的地址
  • 成功后将用户的地址放入到微信提供的缓存中,键设置为: address

在实现以上逻辑之前,需要将微信提供的API封装成Promise形式,避免回调地狱

// utils/asyncWx.js// 封装 获取用户授权信息
export const getSetting = () =>{return new Promise((resolve, reject)=>{wx.getSetting({success: res=>{resolve(res)},fail: err=>{reject(err)}})})
}// 封装 获取地址API
export const chooseAddress = () =>{return new Promise((resolve, reject)=>{wx.chooseAddress({succcess: res=>{resolve(res)},fail: err =>{reject(err)}})})
}// 封装 重新授权API
export const openSetting = () =>{return new Promise((resolve, reject) =>{wx.openSetting({success: res=>{resolve(res)},fail: err =>{reject(err)}})})
}

之后利用上面封装的接口,实现获取收货地址的逻辑

// pages/cart/index.jsimport { getSetting, chooseAddress, openSetting } from "../../utils/asyncWx.js";Page({// 点击 获取收货地址async handleChooseAddress() {try{// 获取权限状态const res1 = await getSetting();const scopeAddress = res1.authSetting["scope.address"];// 判断是否授权if(scopeAddress == false){// 未授权, 重新获取授权await openSetting();}// 到这里是获取了授权, 直接获取用户的地址信息const address = await chooseAddress();// 将用户的地址信息缓存到微信提供的缓存中.wx.setStorageSync("address", address);} catch (err){console.log(err);}}
})

4.文字省略的样式

4.1 展示

需求: 在项目中,有的文字出现长度,超过了给定长度,这个时候,往往需要将超出部分隐藏,用省略号代替
在这里插入图片描述
以上第二行超出了长度.用省略号表示

4.2栗子

栗子: 下面给出一个标题部分,第二行超出隐藏用省略号代替的栗子

.goods_name{display: -webkit-box;overflow: hidden;-webkit-box-orient: vertival;-webkit-line-clamp: 2;
}

5. 购物车页面跳转

需求: 购物车完成结算验证之后会跳转到支付页面。关键API在navigateTo.

下面附上购物车的计算部分代码

<!--pages/cart/index.wxml-->
<!-- 结算 -->
<view class="order_pay_wrap" bindtap="handlPay">结算{{totalNum}}
</view>
// pages/cart/index.js
Page({async handlPay(){const {address, totalNum } = this.data;// 判断有没有选择收货地址if(!address.userName) {await showToast({ title: "您还没有选中收货地址" })return;}// 判断商品数量if(totalNum ==0 ){await showToast({ title: "您还没有选购商品" });return;}// 跳转到支付页面wx.navigateTo({url: "/pages/pay/index"})}
})

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

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

相关文章

Axure实现多用户注册验证

*****多用户登录验证***** 一、&#xff08;常规想法&#xff09;方法&#xff1a;工作量较大&#xff0c;做起来繁琐 1、当用户名和密码相同时怎么区分两者&#xff0c;使用冒号和括号来区分&#xff1a; eg. (admin:123456)(123456:demo)(zhang:san);由此得出前面是括号后面是…

Maximum Xor Secondary(单调栈好题)

Maximum Xor Secondary CodeForces - 280B Bike loves looking for the second maximum element in the sequence. The second maximum element in the sequence of distinct numbers x1, x2, ..., xk (k > 1) is such maximum element xj, that the following inequa…

杂项-公司:唯品会

ylbtech-杂项-公司&#xff1a;唯品会唯品会公司成立于2008年08月&#xff0c;2012年3月23日登陆美国纽约证券交易所上市&#xff08;股票代码&#xff1a;VIPS&#xff09;。成为华南第一家在美国纽交所上市的电子商务企业。主营B2C商城唯品会名牌折扣网站是一家致力于打造中高…

Linux基本的操作

一、为什么我们要学习Linux 相信大部分人的PC端都是用Windows系统的&#xff0c;那我们为什么要学习Linux这个操作系统呢&#xff1f;&#xff1f;&#xff1f;Windows图形化界面做得这么好&#xff0c;日常基本使用的话&#xff0c;学习成本几乎为零。 而Linux不一样&#xff…

汇编语言 实验4

实验4 实验内容1&#xff1a;综合使用 loop,[bx]&#xff0c;编写完整汇编程序&#xff0c;实现向内存 b800:07b8 开始的连续 16 个 字单元重复填充字数据 0403H&#xff1b;修改0403H为0441H&#xff0c;再次运行 步骤1&#xff1a;在记事本中编写好temp.asm文件 步骤2&#x…

LDAP第三天 MySQL+LDAP 安装

https://www.easysoft.com/applications/openldap/back-sql-odbc.html OpenLDAP 使用 SQLServer 和 Oracle 数据库。 https://www.cnblogs.com/bigbrotherer/p/7251372.html          CentOS7安装OpenLDAPMySQLPHPLDAPadmin 1.安装和设置数据库 在CentOS7下&…

Myeclipse连接Mysql数据库时报错:Error while performing database login with the pro driver:unable...

driver template: Mysql connector/j&#xff08;下拉框进行选择&#xff09; driver name: 任意填&#xff0c;最好是数据库名称&#xff0c;方便查找 connection URL: jdbc:mysql://localhost:3306/programmableweb User name: 用户名 password: 密码 Driver jars: 添加jar包…

matlab --- 图像处理基础

MATLAB图像处理 1. 数字图像处理 参考 数字图像处理(Digital Image Processing)又称为计算机图像处理,是一种将图像信号数字化利用计算进行处理的过程。随着计算机科学、电子学和光学的发展,数字图像处理已经广泛的应用到诸多领域之中。本小节主要介绍图像的概念、分类和数字…

[python、flask] - POST请求

1. 微信小程序POST传递数据给flask服务器 小程序端 // 提交POST数据 import { request } from "../../request/index.js"async handleDetectionPoints() {let params {url: "/detect_points",data: {"points": arr,"img_name": thi…

[vue]data数据属性及ref获取dom

data项的定义 this.$refs获取dom 获取不到数据 这样中转下才ok 小结: data里不能用this.$ref. 另外使用visjs时候 view-source:http://visjs.org/examples/network/basicUsage.html 加载不出东西,点了按钮触发才ok 小结: create里应该是从上到下执行的. 转载于:https://www.cnb…

[异步、tensorflow] - 子线程操作tensor,主线程处理tensor

参考整体流程如下图 代码 import tensorflow as tf"""模拟: 子线程不停的取数据放入队列中, 主线程从队列中取数据执行包含: 作用域的命名、把程序的图结构写入事件、多线程 """# 模拟异步存入样本. # 1、 定义一个队列,长度为1000 with tf.va…

Element

官网&#xff1a;http://element-cn.eleme.io/#/zh-CN 转载于:https://www.cnblogs.com/weibanggang/p/9995433.html

[tensorflow] - csv文件读取

参考 文件流程 csv读取流程 函数的流程 import tensorflow as tf import os"""tensorflow中csv文件的读取1、 先找到文件,构造一个列表2、 构造一个文件队列3、 读取(read)队列内容csv: 读取一行二进制文件: 指定一个样本的bytes读取图片文件: 按一张一张…

课程模块表结构

课程模块 我们要开始写课程模块了~~课程模块都有哪些功能呢~~ 我们的课程模块&#xff0c;包括了免费课程以及专题课程两个方向~~ 主要是课程的展示&#xff0c;点击课程进入课程详细页面~~ 课程详细页面展示&#xff0c;课程的概述&#xff0c;课程的价格策略&#xff0c;课程…

[tensorflow、神经网络] - 使用tf和mnist训练一个识别手写数字模型,并测试

参考 包含: 1.层级的计算、2.训练的整体流程、3.tensorboard画图、4.保存/使用模型、5.总体代码(含详细注释) 1. 层级的计算 如上图,mnist手写数字识别的训练集提供的图片是 28 * 28 * 1的手写图像,初始识别的时候,并不知道一次要训练多少个数据,因此输入的规模为 [None, 784].…

面向过程、面向函数、面向对象的区别浅谈

Python的面向过程、面向函数、面向对象的区别浅谈 转自--猎奇古今&#xff0c;加上其他 有人之前私信问我&#xff0c;python编程有面向过程、面向函数、面向对象三种&#xff0c;那么他们区别在哪呢&#xff1f; 面向过程就是将编程当成是做一件事&#xff0c;要按步骤完成&am…

[pytorch、学习] - 3.5 图像分类数据集

参考 3.5. 图像分类数据集 在介绍shftmax回归的实现前我们先引入一个多类图像分类数据集 本章开始使用pytorch实现啦~ 本节我们将使用torchvision包,它是服务于PyTorch深度学习框架的,主要用来构建计算机视觉模型。torchvision主要由以下几部分构成: torchvision.datasets: …

[pytorch、学习] - 3.6 softmax回归的从零开始实现

参考 3.6 softmax回归的从零开始实现 import torch import torchvision import numpy as np import sys sys.path.append("..") import d2lzh_pytorch as d2l3.6.1. 获取和读取数据 batch_size 256 train_iter, test_iter d2l.load_data_fashion_mnist(batch_si…

[pytorch、学习] - 3.7 softmax回归的简洁实现

参考 3.7. softmax回归的简洁实现 使用pytorch实现softmax import torch from torch import nn from torch.nn import init import numpy as np import sys sys.path.append("..") import d2lzh_pytorch as d2l3.7.1. 获取和读取数据 batch_size 256 train_iter…

[pytorch、学习] - 3.9 多重感知机的从零开始实现

参考 3.9 多重感知机的从零开始实现 import torch import numpy as np import sys sys.path.append("..") import d2lzh_pytorch as d2l3.9.1. 获取和读取数据 batch_size 256 train_iter, test_iter d2l.load_data_fashion_mnist(batch_size)3.9.2. 定义模型参…