Bootstrap

小程序商城全过程-附详细代码

由于小程序商城的代码非常复杂且涉及到很多方面,无法在这里一一列举出来。但是,我可以简单介绍一下小程序商城的代码结构和主要功能模块。

小程序商城的代码结构通常包括以下几个主要目录和文件:

  1. pages目录:用于存放小程序的页面文件,每个页面通常由一个文件夹和至少两个文件组成,包括js文件、wxml文件和wxss文件。

  2. components目录:用于存放小程序的组件文件,组件可以在多个页面中复用。

  3. utils目录:用于存放小程序的工具文件,包括一些通用的函数、工具类等。

  4. api目录:用于存放小程序与后端API接口相关的文件,包括封装的请求函数、数据模型等。

  5. assets目录:用于存放小程序的静态资源文件,如图片、图标等。

主要功能模块包括:

  1. 首页:展示商品的轮播图、推荐商品等,点击商品可以进入商品详情页。

  2. 商品列表页:展示所有商品的列表,可以根据分类、关键字等进行筛选。

  3. 商品详情页:展示商品的详细信息,包括商品图片、价格、库存等,可以选择商品数量、加入购物车或直接购买。

  4. 购物车:展示已选中的商品,可以修改商品数量、删除商品等。

  5. 订单确认页:展示已选中的商品、总价等信息,可以选择收货地址、支付方式等。

  6. 订单列表页:展示用户的所有订单信息,包括待付款、待发货、待收货、已完成等状态。

  7. 收货地址管理:展示用户的收货地址列表,可以新增、编辑、删除收货地址。

  8. 用户登录、注册、个人中心等功能。

以上只是小程序商城的一些主要功能模块,具体的代码实现如下:

1. 首页(index.js):

Page({
  data: {
    banners: [], // 轮播图数据
    recommendList: [], // 推荐商品列表
  },
  onLoad: function () {
    // 通过API请求获取轮播图数据和推荐商品列表数据
    // 并将数据更新到data中
    this.setData({
      banners: [...], // 轮播图数据
      recommendList: [...], // 推荐商品列表
    });
  },
});

2. 商品列表页(goodsList.js):

Page({
  data: {
    goodsList: [], // 商品列表数据
  },
  onLoad: function () {
    // 通过API请求获取商品列表数据
    // 并将数据更新到data中
    this.setData({
      goodsList: [...], // 商品列表数据
    });
  },
  onItemClick: function (event) {
    // 点击商品项,跳转到商品详情页
    const goodsId = event.currentTarget.dataset.goodsId;
    wx.navigateTo({
      url: '/pages/goodsDetail/goodsDetail?id=' + goodsId,
    });
  },
});

3. 商品详情页(goodsDetail.js):

Page({
  data: {
    goodsInfo: {}, // 商品详情数据
  },
  onLoad: function (options) {
    const goodsId = options.id;
    // 通过API请求获取商品详情数据
    // 并将数据更新到data中
    this.setData({
      goodsInfo: {...}, // 商品详情数据
    });
  },
  onAddToCart: function () {
    // 将商品添加到购物车
    // 调用API请求将商品加入购物车
    // 提示添加成功
    wx.showToast({
      title: '添加成功',
      icon: 'success',
    });
  },
});

以下是小程序商城的购物车、订单确认页和订单列表页的代码示例。

4. 购物车(cart.js):

Page({
  data: {
    cartList: [], // 购物车商品列表
    totalPrice: 0, // 购物车商品总价
  },
  onLoad: function () {
    // 通过API请求获取购物车商品列表数据
    // 并将数据更新到data中
    this.setData({
      cartList: [...], // 购物车商品列表数据
    });
    // 计算购物车商品总价
    this.calculateTotalPrice();
  },
  onQuantityChange: function (event) {
    // 修改购物车商品数量
    const cartItemId = event.currentTarget.dataset.cartItemId;
    const newQuantity = event.detail.value;
    // 调用API请求修改购物车商品数量
    // 提示修改成功
    wx.showToast({
      title: '修改成功',
      icon: 'success',
    });
    // 更新购物车商品列表数据
    this.setData({
      cartList: [...], // 更新后的购物车商品列表数据
    });
    // 重新计算购物车商品总价
    this.calculateTotalPrice();
  },
  onDeleteItem: function (event) {
    // 删除购物车商品
    const cartItemId = event.currentTarget.dataset.cartItemId;
    // 调用API请求删除购物车商品
    // 提示删除成功
    wx.showToast({
      title: '删除成功',
      icon: 'success',
    });
    // 更新购物车商品列表数据
    this.setData({
      cartList: [...], // 更新后的购物车商品列表数据
    });
    // 重新计算购物车商品总价
    this.calculateTotalPrice();
  },
  calculateTotalPrice: function () {
    // 计算购物车商品总价
    let totalPrice = 0;
    for (let item of this.data.cartList) {
      totalPrice += item.price * item.quantity;
    }
    this.setData({
      totalPrice: totalPrice.toFixed(2), // 保留两位小数
    });
  },
});

5. 订单确认页(orderConfirm.js):

Page({
  data: {
    selectedGoodsList: [], // 已选中的商品列表
    totalPrice: 0, // 订单总价
    address: {}, // 收货地址
    paymentMethod: '', // 支付方式
  },
  onLoad: function () {
    // 通过API请求获取已选中的商品列表数据、默认收货地址数据等
    // 并将数据更新到data中
    this.setData({
      selectedGoodsList: [...], // 已选中的商品列表数据
      totalPrice: 0, // 订单总价
      address: {...}, // 收货地址数据
      paymentMethod: '', // 支付方式数据
    });
    // 计算订单总价
    this.calculateTotalPrice();
  },
  onAddressChange: function (event) {
    // 选择收货地址
    // 跳转到收货地址管理页面
    wx.navigateTo({
      url: '/pages/addressList/addressList',
    });
  },
  onPaymentMethodChange: function (event) {
    // 选择支付方式
    const paymentMethod = event.detail.value;
    this.setData({
      paymentMethod: paymentMethod,
    });
  },
  onSubmitOrder: function () {
    // 提交订单
    // 调用API请求提交订单
    // 提示提交成功
    wx.showToast({
      title: '提交成功',
      icon: 'success',
    });
    // 跳转到订单列表页
    wx.navigateTo({
      url: '/pages/orderList/orderList',
    });
  },
  calculateTotalPrice: function () {
    // 计算订单总价
    let totalPrice = 0;
    for (let item of this.data.selectedGoodsList) {
      totalPrice += item.price * item.quantity;
    }
    this.setData({
      totalPrice: totalPrice.toFixed(2), // 保留两位小数
    });
  },
});

6. 订单列表页(orderList.js):

Page({
  data: {
    orderList: [], // 订单列表数据
  },
  onLoad: function () {
    // 通过API请求获取订单列表数据
    // 并将数据更新到data中
    this.setData({
      orderList: [...], // 订单列表数据
    });
  },
  onOrderDetail: function (event) {
    // 查看订单详情
    const orderId = event.currentTarget.dataset.orderId;
    // 跳转到订单详情页
    wx.navigateTo({
      url: '/pages/orderDetail/orderDetail?id=' + orderId,
    });
  },
});

7. 收货地址管理(addressList.js):

Page({
  data: {
    addressList: [], // 收货地址列表数据
  },
  onLoad: function () {
    // 通过API请求获取收货地址列表数据
    // 并将数据更新到data中
    this.setData({
      addressList: [...], // 收货地址列表数据
    });
  },
  onAddAddress: function () {
    // 新增收货地址
    // 跳转到新增收货地址页面
    wx.navigateTo({
      url: '/pages/addAddress/addAddress',
    });
  },
  onEditAddress: function (event) {
    // 编辑收货地址
    const addressId = event.currentTarget.dataset.addressId;
    // 跳转到编辑收货地址页面
    wx.navigateTo({
      url: '/pages/editAddress/editAddress?id=' + addressId,
    });
  },
  onDeleteAddress: function (event) {
    // 删除收货地址
    const addressId = event.currentTarget.dataset.addressId;
    // 调用API请求删除收货地址
    // 提示删除成功
    wx.showToast({
      title: '删除成功',
      icon: 'success',
    });
    // 更新收货地址列表数据
    this.setData({
      addressList: [...], // 更新后的收货地址列表数据
    });
  },
});

8. 新增收货地址(addAddress.js):

Page({
  data: {
    name: '', // 收货人姓名
    phone: '', // 收货人手机号
    province: '', // 省份
    city: '', // 城市
    district: '', // 区县
    address: '', // 详细地址
  },
  onNameChange: function (event) {
    // 修改收货人姓名
    const name = event.detail.value;
    this.setData({
      name: name,
    });
  },
  onPhoneChange: function (event) {
    // 修改收货人手机号
    const phone = event.detail.value;
    this.setData({
      phone: phone,
    });
  },
  onProvinceChange: function (event) {
    // 修改省份
    const province = event.detail.value;
    this.setData({
      province: province,
    });
  },
  onCityChange: function (event) {
    // 修改城市
    const city = event.detail.value;
    this.setData({
      city: city,
    });
  },
  onDistrictChange: function (event) {
    // 修改区县
    const district = event.detail.value;
    this.setData({
      district: district,
    });
  },
  onAddressChange: function (event) {
    // 修改详细地址
    const address = event.detail.value;
    this.setData({
      address: address,
    });
  },
  onSaveAddress: function () {
    // 保存收货地址
    // 调用API请求保存收货地址
    // 提示保存成功
    wx.showToast({
      title: '保存成功',
      icon: 'success',
    });
    // 返回上一页
    wx.navigateBack();
  },
});

9. 编辑收货地址(editAddress.js):

Page({
  data: {
    addressId: '', // 收货地址ID
    name: '', // 收货人姓名
    phone: '', // 收货人手机号
    province: '', // 省份
    city: '', // 城市
    district: '', // 区县
    address: '', // 详细地址
  },
  onLoad: function (options) {
    // 获取收货地址ID
    const addressId = options.id;
    // 通过API请求获取收货地址详情数据
    // 并将数据更新到data中
    this.setData({
      addressId: addressId,
      name: '', // 收货人姓名
      phone: '', // 收货人手机号
      province: '', // 省份
      city: '', // 城市
      district: '', // 区县
      address: '', // 详细地址
    });
  },
  onNameChange: function (event) {
    // 修改收货人姓名
    const name = event.detail.value;
    this.setData({
      name: name,
    });
  },
  onPhoneChange: function (event) {
    // 修改收货人手机号
    const phone = event.detail.value;
    this.setData({
      phone: phone,
    });
  },
  onProvinceChange: function (event) {
    // 修改省份
    const province = event.detail.value;
    this.setData({
      province: province,
    });
  },
  onCityChange: function (event) {
    // 修改城市
    const city = event.detail.value;
    this.setData({
      city: city,
    });
  },
  onDistrictChange: function (event) {
    // 修改区县
    const district = event.detail.value;
    this.setData({
      district: district,
    });
  },
  onAddressChange: function (event) {
    // 修改详细地址
    const address = event.detail.value;
    this.setData({
      address: address,
    });
  },
  onSaveAddress: function () {
    // 保存收货地址
    // 调用API请求保存收货地址
    // 提示保存成功
    wx.showToast({
      title: '保存成功',
      icon: 'success',
    });
    // 返回上一页
    wx.navigateBack();
  },
});

10. 用户登录(login.js):

Page({
  data: {
    username: '', // 用户名
    password: '', // 密码
  },
  onUsernameChange: function (event) {
    // 修改用户名
    const username = event.detail.value;
    this.setData({
      username: username,
    });
  },
  onPasswordChange: function (event) {
    // 修改密码
    const password = event.detail.value;
    this.setData({
      password: password,
    });
  },
  onLogin: function () {
    // 用户登录
    // 调用API请求用户登录
    // 提示登录成功
    wx.showToast({
      title: '登录成功',
      icon: 'success',
    });
    // 跳转到个人中心页
    wx.navigateTo({
      url: '/pages/profile/profile',
    });
  },
});

11. 用户注册(register.js):

Page({
  data: {
    username: '', // 用户名
    password: '', // 密码
    confirmPassword: '', // 确认密码
  },
  onUsernameChange: function (event) {
    // 修改用户名
    const username = event.detail.value;
    this.setData({
      username: username,
    });
  },
  onPasswordChange: function (event) {
    // 修改密码
    const password = event.detail.value;
    this.setData({
      password: password,
    });
  },
  onConfirmPasswordChange: function (event) {
    // 修改确认密码
    const confirmPassword = event.detail.value;
    this.setData({
      confirmPassword: confirmPassword,
    });
  },
  onRegister: function () {
    // 用户注册
    // 调用API请求用户注册
    // 提示注册成功
    wx.showToast({
      title: '注册成功',
      icon: 'success',
    });
    // 跳转到登录页
    wx.navigateTo({
      url: '/pages/login/login',
    });
  },
});

12. 个人中心(profile.js):

Page({
  data: {
    username: '', // 用户名
    avatar: '', // 头像
    gender: '', // 性别
    phone: '', // 手机号
    email: '', // 邮箱
    address: '', // 收货地址
  },
  onLoad: function () {
    // 通过API请求获取个人信息数据
    // 并将数据更新到data中
    this.setData({
      username: '', // 用户名
      avatar: '', // 头像
      gender: '', // 性别
      phone: '', // 手机号
      email: '', // 邮箱
      address: '', // 收货地址
    });
  },
  onLogout: function () {
    // 用户退出登录
    // 调用API请求用户退出登录
    // 提示退出成功
    wx.showToast({
      title: '退出成功',
      icon: 'success',
    });
    // 跳转到登录页
    wx.navigateTo({
      url: '/pages/login/login',
    });
  },
});

以上代码仅为示例,实际开发中可能需要更多的逻辑处理和数据请求。具体的代码实现还需要根据具体需求和后端API接口进行调整。

;