当前位置: 首页 > wzjs >正文

手机网站后台怎样在百度上发布广告

手机网站后台,怎样在百度上发布广告,wordpress网站欣赏,怎么用家里的电脑做网站服务器阶段 2 – 购物车(超详细版) 目标 把“加入购物车”做成 全局状态,任何页面都能读写在本地 持久化(关闭小程序后购物车仍在)新建 购物车页:数量增减、总价实时计算、去结算入口打 Git Tag v2.0‑cart 1. …

阶段 2 – 购物车(超详细版)

目标

  1. 把“加入购物车”做成 全局状态,任何页面都能读写
  2. 在本地 持久化(关闭小程序后购物车仍在)
  3. 新建 购物车页:数量增减、总价实时计算、去结算入口
  4. 打 Git Tag v2.0‑cart

1. 学到的核心技术

技术/概念关键 API/组件为什么要学
全局状态App.globalData / 简易 store.js小项目先不引入第三方状态库,足够用
本地持久化wx.setStorageSync / wx.getStorageSync保证用户切后台、重进小程序后数据不丢
UI 组件(弹出购物车)
 (底部结算条)
 (数量加减)
快速完成电商式交互
TabBar Badgewx.setTabBarBadge在底部“购物车”图标上显示件数

2. 项目结构新增

miniprogram/├─ store/          # 新增│   └─ cart.js├─ pages/│   ├─ index/      # 首页已存在│   └─ cart/       # 新建购物车页面

3. 编写轻量级全局 Store

路径miniprogram/store/cart.js

const CART_KEY = 'CART_V1'
const store = {data: { items: {} },load() {this.data.items = wx.getStorageSync(CART_KEY) || {}},save() {wx.setStorageSync(CART_KEY, this.data.items)},add(dish) {const { _id } = dishif (this.data.items[_id]) {this.data.items[_id].count += 1} else {this.data.items[_id] = { ...dish, count: 1 }}this.save()},totalCount() {return Object.values(this.data.items).reduce((s, i) => s + i.count, 0)},totalPrice() {return Object.values(this.data.items).reduce((s, i) => s + i.count * i.price, 0).toFixed(2)}}
module.exports = store

4. 在 app.js 中加载购物车

// miniprogram/app.js
App({onLaunch() {const cart = require('./store/cart')cart.load()this.globalData = { cart }}
})

5. 修改首页:加入购物车 & 更新角标

文件pages/index/index.js

只需要把之前的 onAddCart 改成:

import cart from '../../store/cart'onAddCart(e) {const dish = e.currentTarget.dataset.dishcart.add(dish)wx.setTabBarBadge({ index: 1, text: String(cart.totalCount()) })wx.showToast({ title: '已加入购物车', icon: 'success' })}
}

提示:在 app.jsontabBar 数组里,把第二项页面路径设成 "pages/cart/index",这样角标才会显示在购物车图标上。


6. 新建购物车页面

6.1 组件声明 pages/cart/index.json
{"navigationBarTitleText": "购物车"
}
6.2 页面布局 index.wxml
<view class="page"><block wx:for="{{list}}" wx:key="_id"><view class="cart-item"><image class="thumb" src="{{item.img}}" mode="aspectFill" /><view class="info"><text class="name">{{item.name}}</text><text class="price">¥{{item.price}}</text><text class="count">x {{item.count}}</text></view></view></block><view class="bottom-bar"><text>共 {{totalCount}} 件</text><text>合计:¥{{totalPrice}}</text><button type="primary" bindtap="onCheckout">去结算</button></view>
</view>
6.3 页面逻辑 index.js
const cart = require('../../store/cart')Page({data: {list: [],totalCount: 0,totalPrice: '0.00'},onShow() {cart.load()this.refresh()},refresh() {const items = Object.values(cart.data.items)const totalCount = cart.totalCount()const totalPrice = cart.totalPrice()this.setData({list: items,totalCount,totalPrice})},onCheckout() {if (!this.data.totalCount) {wx.showToast({ title: '购物车为空', icon: 'none' })return}wx.navigateTo({ url: '/pages/confirm/index' }) // 下一阶段页}
})
6.4 简单样式 index.wxss
.page {padding: 20rpx;
}.cart-item {display: flex;background: #fff;padding: 20rpx;margin-bottom: 20rpx;border-radius: 16rpx;box-shadow: 0 4rpx 12rpx rgba(0,0,0,0.05);
}.thumb {width: 100rpx;height: 100rpx;border-radius: 8rpx;margin-right: 20rpx;
}.info {display: flex;flex-direction: column;justify-content: space-around;
}.name {font-weight: bold;font-size: 32rpx;
}.price {color: #fa541c;
}.count {font-size: 28rpx;color: #888;
}.bottom-bar {position: fixed;bottom: 0;left: 0;width: 100%;background: #fff;padding: 20rpx;display: flex;justify-content: space-between;box-shadow: 0 -2rpx 12rpx rgba(0,0,0,0.1);
}

7. TabBar 配置示例

// app.json(节选)
"tabBar": {"list": [{ "pagePath": "pages/index/index", "text": "菜单", "iconPath": "images/icons/home.png", "selectedIconPath": "images/icons/home-active.png" },{ "pagePath": "pages/cart/index",  "text": "购物车", "iconPath": "images/icons/business.png", "selectedIconPath": "images/icons/business-active.png" }]}

在这里插入图片描述

8. 自测清单 & Git Tag

  1. 首页点两道菜 → 角标显示 2
  2. 进入购物车页
    • 看得到两条记录
  3. 关闭小程序再打开 → 数据依旧存在
  4. 一切通过后:
git add .
git commit -m "feat: shopping cart"
git tag v2.0-cart
git push --tags

9. 练习(进阶挑战)

难度练习内容
cart.js 增加 clear() 方法,在购物车页提供“一键清空”。
⭐⭐在首页卡片上显示当前已选数量(小圆角徽标)。
⭐⭐⭐把 Store 升级为 PiniaRemax Recoil,体验响应式自动刷新。

阶段小结

  • 你已拥有 加入购物车 → 全局状态 → 本地持久化 → 购物车 UI 的完整链路。
  • 代码量 ≈ 250 行,但逻辑清晰、易维护。
  • 接下来进入 阶段 3 – 下单 & 云数据库:把购物车内容写入 orders 集合,实现真正的下单流程。

继续加油,愉快编码!

http://www.dtcms.com/wzjs/376044.html

相关文章:

  • 医院网站建设方案网站宣传推广方案
  • 如何做自己公司的网站seo指的是
  • 手机网站开发费用爱站关键词
  • 微信分销系统多少钱360优化大师官方最新
  • 网站城市分站是怎么做的长沙网站定制公司
  • 做网络作家哪个网站好怎么免费创建网站
  • 怎样用一台电脑做代理 让别的电脑通过代理上几个网站俄罗斯搜索引擎入口 yandex
  • 企业网站建设 信科网络百度竞价推广自己可以做吗
  • 分类网站建设方案河北网站优化公司
  • 深圳营销型网站费用石家庄最新消息今天
  • 如何查网站的备案信息如何搭建网站
  • 做海报去哪个网站找素材比较好呢排名优化系统
  • 广州地区做网站的关键词歌词打印
  • 网站网站建设设计公司seo诊断方案
  • 网站首页做跳转互联网广告公司排名前十
  • 无锡市做企业网站的seo外包靠谱
  • 番禺高端网站建设公司百度账户
  • 网站建设卖手机代码seo优化就业前景
  • 好的交互设计网站友情链接购买平台
  • 山东滨州网站建设公司河南网站开发公司
  • 即时聊天wordpress手机app免费seo视频教学
  • 企业网站建设费用计入什么科目google网站搜索
  • 提升了自己的网站杭州网站优化公司
  • 做3d动画网站长春网站制作
  • 电影网站嵌入广告怎么做Java专业网络推广软件
  • 网站后台设置百度在线翻译
  • 对象储存做网站怎么做营销推广方案
  • asp网站做消息提醒功能怎么做好推广和营销
  • 广东公诚通信建设监理有限公司网站郑州百度快照优化
  • 建筑工具网站关键词调词平台费用