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

1. 点击放大功能的实现

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

<!-- pages/goods_detail/index.wxml -->
<!-- 轮播图 -->
<view class="detail_swiper">
    <swiper
    autoplay
    circular
    indicator-dots
    >
        <swiper-item
         wx: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.dataset
        const 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>
    <navigator
       open-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.js

import { 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"
        })
    }
})

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个航空系统管理员页面内容的示例: ```html <div class="container"> <h1>航空系统管理员页面</h1> <h2>航班管理</h2> <div class="flight-management"> <form id="add-flight-form"> <label for="flight-number">航班号:</label> <input type="text" id="flight-number" name="flight-number" required><br> <label for="departure">出发地:</label> <input type="text" id="departure" name="departure" required><br> <label for="destination">目的地:</label> <input type="text" id="destination" name="destination" required><br> <button type="submit">添加航班</button> </form> <table id="flight-list"> <tr> <th>航班号</th> <th>出发地</th> <th>目的地</th> <th>操作</th> </tr> <!-- 这里使用JavaScript从后端获取航班列表并动态添加到表格中 --> </table> </div> <h2>乘客管理</h2> <div class="passenger-management"> <table id="passenger-list"> <tr> <th>姓名</th> <th>性别</th> <th>航班号</th> <th>座位号</th> </tr> <!-- 这里使用JavaScript从后端获取乘客列表并动态添加到表格中 --> </table> </div> </div> ``` 这是一个简单的航空系统管理员页面示例,包含航班管理和乘客管理两个部分。在航班管理部分,您可以通过表单添加新的航班,并显示已有航班的列表。在乘客管理部分,您可以显示乘客的列表。 请注意,上述示例中的JavaScript部分被省略了,您需要根据实际情况添加相应的JavaScript代码来实现从后端获取数据并动态添加到表格中的功能
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值