taro 实现购物车逻辑
效果
taro是什么?
Taro 是一套遵循 React 语法规范的 多端开发 解决方案。
- 现如今市面上端的形态多种多样,Web、React-Native、微信小程序等各种端大行其道,当业务要求同时在不同的端都要求有所表现的时候,针对不同的端去编写多套代码的成本显然非常高,这时候只编写一套代码就能够适配到多端的能力就显得极为需要。
- 使用 Taro,我们可以只书写一套代码,再通过 Taro 的编译工具,将源代码分别编译出可以在不同端(微信/百度/支付宝/字节跳动/QQ/京东小程序、快应用、H5、React-Native 等)运行的代码。本代码是基于Taro UI 开发的,虽然是基于 taro框架开发的,但购物车的整体逻辑与微信小程序逻辑是基本一样的
- Taro UI是一款基于 Taro 框架开发的多端 UI 组件库
需要安装taro ui
$ npm install taro-ui
taro官方文档
taroUI 官方文档
cart/index.jsx页面代码
import Taro, { Component } from '@tarojs/taro'
import { View, Checkbox, CheckboxGroup } from '@tarojs/components'
//用到了taro的三个组件
//想了解可以去查看taro的官方文档
import './index.scss'
import { AtButton, AtInputNumber, AtCard } from 'taro-ui'
import { request, toast } from '../../utils/index'
class Index extends Component {
constructor(props) {
super(props)
this.state = {
message: '', //购物车为空时显示的信息
cartdata: [], //购物车的数据列表
isactive: false, //全选按钮是否选中
check:false, //单个商品购物车是否被选中
totalnum:0, //总数量
totalprice:0, //总价格
activedata:[] //复选框选中的数据列表
}
}
componentDidShow () {
//获取购物车数据
try {
const token = Taro.getStorageSync('token') //这两个数据是我在登录页面,登录时添加到本地的token和用户id
const userid = Taro.getStorageSync('userid')
if (token) { //如果登录了
const usrename = Taro.getStorageSync('username') //同样登录时添加到本地的用户名
Taro.setNavigationBarTitle({ //改变导航栏的标题
title: usrename + '---购物车'
})
request({ //这里的request是封装后的方法
url: '/cart', //接口
data: { //需要传递的数据
token,
userid
}
}).then(res => {
console.log(res.data)
const { code } = res.data
if (code === '10119') { //后端返回的值 ,判断状态
toast({ title: '登录已经过期,请从新登录' })
Taro.navigateTo({ //跳转到登录页
url: '/pages/login/index'
})
} else if (code === '10012') {
this.setState({
message: '购物车空空如也'
})
} else {
//因为taro是基于react的,在react中,状态不能直接改变,要用this.setState
this.setState({ //登录成功,购物车有数据时,将购物车的列表数据添加到购物车数据中
cartdata: res.data.data
})
}
})
} else { //如果没登录
toast({ title: '请登录' })
Taro.navigateTo({ //跳转到登录页面
url: '/pages/login/index'
})
}
} catch (e) {
}
}
componentDidUpdate(){
//计算总数量,总价格
let num=0;
let price=0;
if(this.state.activedata.length!=0){ //如果选中的数组长度不为0时,就是有商品被选中了
this.state.activedata.map((item)=>{ //map遍历数组
num+= +item.num //将数量相加 + 号为一元运算符,将字符串类型转换为数值类型
price+=item.num*item.price //求价格
})
this.setState({ //设置值
totalnum:num,
totalprice:price
})
}else{ //如果没有商品被选中
this.setState({
totalnum:0,
totalprice:0
})
}
}
render() {
return ( //结构开始
<View>{
this.state.message.length === 0 "htmlcode">
cart/index.scss页面代码
@import "~taro-ui/dist/style/components/card.scss";
@import "~taro-ui/dist/style/components/button.scss";
@import "~taro-ui/dist/style/components/loading.scss";
@import "~taro-ui/dist/style/components/icon.scss";
@import "~taro-ui/dist/style/components/input-number.scss";
utils/index.js代码
const publicurl ='',//接口就不放上去了,因为也不是我的,这里就放接口前的公共网址
import Taro from '@tarojs/taro'
export function request(options){
const {url,data,method}=options
wx.showLoading({ //显示loading框
title: '加载中',
})
return new Promise((resolve,reject)=>{
Taro.request({ //数据请求 与小程序类似
url: publicurl+url,
data:data || {},
method:method || 'GET',
success(res){
//成功
resolve(res)
},
fail(err){
//失败
reject(err)
},
complete(){
// complete 接口调用结束的回调函数
wx.hideLoading(); //隐藏loading框
}
})
})
}
export function toast(options){
const {title,icon, duration}=options
Taro.showToast({
title,
icon: icon || 'none',
duration:duration || 1000
})
}
总结
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“taro 实现购物车逻辑的实例代码”评论...
更新动态
2025年11月07日
2025年11月07日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]
