幽灵资源网 Design By www.bzswh.com
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 }) }总结
幽灵资源网 Design By www.bzswh.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
幽灵资源网 Design By www.bzswh.com
暂无评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。