【微信小程序开发】栀子手作花花微信小程序商城开发最佳实践

news/2024/11/16 1:16:32/文章来源:https://www.cnblogs.com/52tech/p/18378081

本文介绍了通过uniapp技术实现了一套栀子手作在线购物商城系统。包含首页、分类、我的等常用功能入口。

一、功能演示

首页:包含了商品介绍,领劵中心和商品列表区域。

商品分类:支持不同的商品分类和商品搜素。

商品详情:包含了商品详细的描述信息,透出了分享、首页、客服等入口。

我的:包含了账户的常见的个人操作信息,知乎此领劵,在线客服,钱包管理等入口。

H5端在线体验地址:https://wx.gaoredu.com/

微信小程序:可以直接搜索“栀子手作”进入在线体验。

二、开发流程

2.1 项目准备与搭建

1. 环境搭建

首先,确保你已经安装了Node.js和HBuilderX,因为uniapp的项目可以通过HBuilderX来方便地创建和管理。安装HBuilderX后,在官网(https://www.dcloud.io/hbuilderx.html)下载并安装。

2. 创建uniapp项目

启动HBuilderX,点击菜单栏中的“文件”→“新建”→“项目”,选择“uni-app”类型,输入项目名称(如“huahuaMall”),选择项目保存路径,点击“创建”按钮。项目创建成功后,你会看到一个基本的项目结构,包括pagesstaticcomponents等目录。

2.2 首页设计

这里是栀子手作的小店的首页设计:

1. 页面布局

首页是商城的门户,通常包含轮播图、搜索框、热门商品列表等功能模块。

  • 轮播图:使用<swiper><swiper-item>组件展示。
  • 搜索框:自定义一个搜索组件,可以放置在<view class="header">中。
  • 商品列表:使用<view v-for="...">循环遍历商品数据,每个商品使用<view class="product-item">展示。

2. 示例代码

<template><view class="container" :style="appThemeStyle"><!-- 店铺页面组件 --><Page :items="items" /><!-- 用户隐私保护提示(仅微信小程序) --><!-- #ifdef MP-WEIXIN --><PrivacyPopup :hideTabBar="true" /><!-- #endif --></view>
</template><script>import { setCartTabBadge } from '@/core/app'import * as Api from '@/api/page'import Page from '@/components/page'import PrivacyPopup from '@/components/privacy-popup'const App = getApp()export default {components: {Page,PrivacyPopup},data() {return {// 页面参数options: {},// 页面属性page: {},// 页面元素items: []}},/*** 生命周期函数--监听页面加载*/onLoad(options) {// 当前页面参数this.options = options// 加载页面数据this.getPageData()},/*** 生命周期函数--监听页面显示*/onShow() {// 更新购物车角标setCartTabBadge()},methods: {/*** 加载页面数据* @param {Object} callback*/getPageData(callback) {const app = thisconst pageId = app.options.pageId || 0Api.detail(pageId).then(result => {// 设置页面数据const { data: { pageData } } = resultapp.page = pageData.pageapp.items = pageData.items// 设置顶部导航栏栏app.setPageBar()}).finally(() => callback && callback())},/*** 设置顶部导航栏*/setPageBar() {const { page } = this// 设置页面标题uni.setNavigationBarTitle({title: page.params.title})// 设置navbar标题、颜色uni.setNavigationBarColor({frontColor: page.style.titleTextColor === 'white' ? '#ffffff' : '#000000',backgroundColor: page.style.titleBackgroundColor})}},/*** 下拉刷新*/onPullDownRefresh() {// 获取首页数据this.getPageData(() => {uni.stopPullDownRefresh()})},/*** 分享当前页面*/onShareAppMessage() {const app = thisconst { page } = appreturn {title: page.params.shareTitle,path: "/pages/index/index?" + app.$getShareUrlParams()}},/*** 分享到朋友圈* 本接口为 Beta 版本,暂只在 Android 平台支持,详见分享到朋友圈 (Beta)* https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/share-timeline.html*/onShareTimeline() {const app = thisconst { page } = appreturn {title: page.params.shareTitle,path: "/pages/index/index?" + app.$getShareUrlParams()}}}
</script><style lang="scss" scoped>.container {background: #fff;}
</style>

2.3 分类页面设计

<template><view class="container"><!-- 搜索框 --><view class="search"><search tips="搜索商品" @event="$navTo('pages/search/index')" /></view><!-- 一级分类 --><primaryv-if="setting.style == PageCategoryStyleEnum.ONE_LEVEL_BIG.value || setting.style == PageCategoryStyleEnum.ONE_LEVEL_SMALL.value":display="setting.style" :list="list" /><!-- 二级分类 --><secondary v-if="setting.style == PageCategoryStyleEnum.TWO_LEVEL.value" :list="list" /><!-- 分类+商品 --><commodity v-if="setting.style == PageCategoryStyleEnum.COMMODITY.value" ref="mescrollItem" :list="list" :setting="setting" /></view>
</template><script>import MescrollCompMixin from '@/uni_modules/mescroll-uni/components/mescroll-uni/mixins/mescroll-comp'import { setCartTabBadge } from '@/core/app'import SettingKeyEnum from '@/common/enum/setting/Key'import { PageCategoryStyleEnum } from '@/common/enum/store/page/category'import SettingModel from '@/common/model/Setting'import * as CategoryApi from '@/api/category'import Search from '@/components/search'import Primary from './components/primary'import Secondary from './components/secondary'import Commodity from './components/commodity'// 最后一次刷新时间let lastRefreshTime;export default {components: {Search,Primary,Secondary,Commodity},mixins: [MescrollCompMixin],data() {return {// 枚举类PageCategoryStyleEnum,// 分类列表list: [],// 分类模板设置setting: {},// 正在加载中isLoading: true}},/*** 生命周期函数--监听页面加载*/onLoad() {// 加载页面数据this.onRefreshPage()},/*** 生命周期函数--监听页面显示*/onShow() {// 每间隔5分钟自动刷新一次页面数据const curTime = new Date().getTime()if ((curTime - lastRefreshTime) > 5 * 60 * 1000) {this.onRefreshPage()}},methods: {// 刷新页面onRefreshPage() {// 记录刷新时间lastRefreshTime = new Date().getTime()// 获取页面数据this.getPageData()// 更新购物车角标setCartTabBadge()},// 获取页面数据getPageData() {const app = thisapp.isLoading = truePromise.all([// 获取分类模板设置// 优化建议: 可以将此处的false改为true 启用缓存SettingModel.data(false),// 获取分类列表CategoryApi.list()]).then(result => {// 初始化分类模板设置app.initSetting(result[0])// 初始化分类列表数据app.initCategory(result[1])}).finally(() => app.isLoading = false)},/*** 初始化分类模板设置* @param {Object} result*/initSetting(setting) {this.setting = setting[SettingKeyEnum.PAGE_CATEGORY_TEMPLATE.value]},/*** 初始化分类列表数据* @param {Object} result*/initCategory(result) {this.list = result.data.list},},/*** 设置分享内容*/onShareAppMessage() {const app = thisreturn {title: _this.templet.shareTitle,path: '/pages/category/index?' + app.$getShareUrlParams()}},/*** 分享到朋友圈* 本接口为 Beta 版本,暂只在 Android 平台支持,详见分享到朋友圈 (Beta)* https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/share-timeline.html*/onShareTimeline() {const app = thisreturn {title: _this.templet.shareTitle,path: '/pages/category/index?' + app.$getShareUrlParams()}}}
</script><style>page {background: #fff;}
</style>
<style lang="scss" scoped>// 搜索框.search {position: fixed;top: var(--window-top);left: var(--window-left);right: var(--window-right);z-index: 9;}
</style>

 

2.4 商品详情页面设计

相关代码演示:

<template><view v-show="!isLoading" class="container" :style="appThemeStyle"><!-- 商品图片轮播 --><SlideImage v-if="!isLoading" :video="goods.video" :videoCover="goods.videoCover":images="goods.goods_images" /><!-- 商品信息 --><view v-if="!isLoading" class="goods-info m-top20"><!-- 价格、销量 --><view class="info-item info-item__top dis-flex flex-x-between flex-y-end"><view class="block-left dis-flex flex-y-center"><!-- 商品售价 --><text class="floor-price__samll">¥</text><text class="floor-price">{{ goods.goods_price_min }}</text><!-- 会员价标签 --><view v-if="goods.is_user_grade" class="user-grade"><text>会员价</text></view><!-- 划线价 --><text v-if="goods.line_price_min > 0" class="original-price">¥{{ goods.line_price_min }}</text></view><view class="block-right dis-flex"><!-- 销量 --><view class="goods-sales"><text>已售{{ goods.goods_sales }}件</text></view></view></view><!-- 标题、分享 --><view class="info-item info-item__name dis-flex flex-y-center"><view class="goods-name flex-box"><text class="twoline-hide">{{ goods.goods_name }}</text></view><view class="goods-share__line"></view><view class="goods-share"><button class="share-btn dis-flex flex-dir-column" @click="onShowShareSheet()"><text class="share__icon iconfont icon-fenxiang"></text><text class="f-24">分享</text></button></view></view><!-- 商品卖点 --><view v-if="goods.selling_point" class="info-item info-item_selling-point"><text>{{ goods.selling_point }}</text></view></view><!-- 选择商品规格 --><view v-if="goods.spec_type == 20" class="goods-choice m-top20 b-f" @click="onShowSkuPopup(1)"><view class="spec-list"><view class="flex-box"><text class="col-8">选择:</text><text class="spec-name" v-for="(item, index) in goods.specList":key="index">{{ item.spec_name }}</text></view><view class="f-26 col-9 t-r"><text class="iconfont icon-arrow-right"></text></view></view></view><!-- 商品服务 --><Service v-if="!isLoading" :goods-id="goodsId" /><!-- 商品SKU弹窗 --><SkuPopup v-if="!isLoading" v-model="showSkuPopup" :skuMode="skuMode" :goods="goods" @addCart="onAddCart" /><!-- 商品评价 --><Comment v-if="!isLoading" :goods-id="goodsId" :limit="2" /><!-- 商品描述 --><view v-if="!isLoading" class="goods-content m-top20"><view class="item-title b-f"><text>商品描述</text></view><view v-if="goods.content != ''" class="goods-content__detail b-f"><mp-html :content="goods.content" /></view></view><!-- 底部选项卡 --><view class="footer-fixed"><view class="footer-container"><!-- 导航图标 --><view class="foo-item-fast"><!-- 首页 --><view class="fast-item fast-item--home" @click="onTargetHome"><view class="fast-icon"><text class="iconfont icon-shouye"></text></view><view class="fast-text"><text>首页</text></view></view><!-- 客服 --><customer-btn v-if="isShowCustomerBtn" :showCard="true" :cardTitle="goods.goods_name":cardImage="goods.goods_image"><view class="fast-item"><view class="fast-icon"><text class="iconfont icon-kefu1"></text></view><view class="fast-text"><text>客服</text></view></view></customer-btn><!-- 购物车 --><!-- <view class="fast-item fast-item--cart" @click="onTargetCart"><view v-if="cartTotal > 0" class="fast-badge fast-badge--fixed">{{ cartTotal > 99 ? '99+' : cartTotal }}</view><view class="fast-icon"><text class="iconfont icon-gouwuche"></text></view><view class="fast-text"><text>购物车</text></view></view> --></view><!-- 操作按钮 --><view class="foo-item-btn"><view class="btn-wrapper"><!-- <view v-if="isEnableCart" class="btn-item btn-item-deputy" @click="onShowSkuPopup(2)"><text>加入购物车</text></view> --><view class="btn-item btn-item-main" @click="onShowSkuPopup(3)"><text>更多详情</text></view></view></view></view></view><!-- 快捷导航 --><!-- <shortcut bottom="120rpx" /> --><!-- 分享菜单 --><share-sheet v-model="showShareSheet" :shareTitle="goods.goods_name" :shareImageUrl="goods.goods_image" /><!-- 二维码扫码 --><u-modal v-model="showQrModal" :title="温馨提示"><view class="qrcode"><text>下单请长按二维码➕微信</text><image src="../../static/qrcode.jpg" mode="widthFix" :show-menu-by-longpress="true"/></view></u-modal></view>
</template><script>import {getSceneData} from '@/core/app'import * as GoodsApi from '@/api/goods'import * as CartApi from '@/api/cart'import SettingModel from '@/common/model/Setting'import {GoodsTypeEnum} from '@/common/enum/goods'import ShareSheet from '@/components/share-sheet'import CustomerBtn from '@/components/customer-btn'import SlideImage from './components/SlideImage'import SkuPopup from './components/SkuPopup'import Comment from './components/Comment'import Service from './components/Service'export default {components: {ShareSheet,CustomerBtn,SlideImage,SkuPopup,Comment,Service},data() {return {// 正在加载isLoading: true,// 当前商品IDgoodsId: null,// 商品详情goods: {},// 购物车总数量cartTotal: 0,// 显示/隐藏SKU弹窗showSkuPopup: false,// 模式 1:都显示 2:只显示购物车 3:只显示立即购买skuMode: 1,// 显示/隐藏分享菜单showShareSheet: false,// 是否支持加入购物车isEnableCart: false,// 是否显示在线客服按钮isShowCustomerBtn: false,// 是否展示QrModalshowQrModal: false,}},/*** 生命周期函数--监听页面加载*/async onLoad(options) {// 记录query参数this.onRecordQuery(options)// 加载页面数据this.onRefreshPage()// 是否显示在线客服按钮this.isShowCustomerBtn = await SettingModel.isShowCustomerBtn()},methods: {// 记录query参数onRecordQuery(query) {const scene = getSceneData(query)this.goodsId = query.goodsId ? parseInt(query.goodsId) : parseInt(scene.gid)},// 刷新页面数据onRefreshPage() {const app = thisapp.isLoading = truePromise.all([app.getGoodsDetail(), app.getCartTotal()]).finally(() => app.isLoading = false)},// 获取商品信息getGoodsDetail() {const app = thisreturn new Promise((resolve, reject) => {GoodsApi.detail(app.goodsId).then(result => {app.goods = result.data.detailif (app.goods.goods_type == GoodsTypeEnum.PHYSICAL.value) {app.isEnableCart = true}resolve(result)}).catch(reject)})},// 获取购物车总数量getCartTotal() {const app = thisreturn new Promise((resolve, reject) => {CartApi.total().then(result => {app.cartTotal = result.data.cartTotalresolve(result)}).catch(reject)})},// 更新购物车数量onAddCart(total) {this.cartTotal = total},/*** 显示/隐藏SKU弹窗* @param {skuMode} 模式 1:都显示 2:只显示购物车 3:只显示立即购买*/onShowSkuPopup(skuMode = 1) {// 下单请联系客服this.showQrModal = true;// uni.showModal({// 	title: '温馨提示',// 	content: '下单请联系客服或➕微信:zzsz68'// });// WARNING:如下临时注释// const app = this// if (app.isEnableCart) {//   app.skuMode = skuMode// } else {//   app.skuMode = 3// }// app.showSkuPopup = !app.showSkuPopup},// 显示隐藏分享菜单onShowShareSheet() {this.showShareSheet = !this.showShareSheet},// 跳转到首页onTargetHome(e) {this.$navTo('pages/index/index')},// 跳转到购物车页onTargetCart() {this.$navTo('pages/cart/index')},},/*** 分享当前页面*/onShareAppMessage() {const app = this// 构建页面参数const params = app.$getShareUrlParams({goodsId: app.goodsId,})return {title: app.goods.goods_name,path: `/pages/goods/detail?${params}`}},/*** 分享到朋友圈* 本接口为 Beta 版本,暂只在 Android 平台支持,详见分享到朋友圈 (Beta)* https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/share-timeline.html*/onShareTimeline() {const app = this// 构建页面参数const params = app.$getShareUrlParams({goodsId: app.goodsId,})return {title: app.goods.goods_name,path: `/pages/goods/detail?${params}`}}}
</script><style>page {background: #fafafa;}
</style>
<style lang="scss" scoped>@import "./detail.scss";
</style>

2.4 我的页面设计

<template><view v-if="!isFirstload" class="container" :style="appThemeStyle"><!-- 页面头部 --><view class="main-header" :style="{ height: platform == 'H5' ? '260rpx' : '320rpx', paddingTop: platform == 'H5' ? '0' : '80rpx' }"><image class="bg-image" src="/static/background/user-header2.png" mode="scaleToFill"></image><!-- 用户信息 --><view v-if="isLogin" class="user-info"><view class="user-avatar" @click="handlePersonal()"><avatar-image :url="userInfo.avatar_url" :width="100" /></view><view class="user-content"><!-- 会员昵称 --><view class="nick-name oneline-hide" @click="handlePersonal()">{{ userInfo.nick_name }}</view><!-- 会员等级 --><view v-if="$checkModule('user-grade') && userInfo.grade_id > 0 && userInfo.grade" class="user-grade"><view class="user-grade_icon"><image class="image"src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAMAAABEpIrGAAAA0lBMVEUAAAD/tjL/tzH/uDP/uC7/tjH/tzH/tzL/tTH+tTL+tjP/tDD/tTD+tzD/tjL/szD/uDH/tjL/tjL+tjD/tjT/szb/tzL/tTL+uTH+tjL/tjL/tjL/tTT/tjL/tjL+tjH/uTL/vDD/tjL/tjH/tzL9uS//tTL/nBr/sS7/tjH/ujL/szD/uTv+rzf/tzL+tzH+vDP+uzL+tjP+ry7+tDL9ki/7szf/sEX/tTL/tjL+tjL/tTH/tTT/tzH/tzL/tjP/sTX/uTP/wzX+rTn/vDX9vC8m8ckhAAAAOXRSTlMAlnAMB/vjxKWGMh0S6drMiVxPRkEY9PLy0ru0sKagmo5+dGtgVCMgBP716eXWyMGxqJGRe2o5KSmFNjaYAAABP0lEQVQ4y8XS13KDMBAF0AWDDe4t7r3ETu9lVxJgJ/n/X8rKAzHG5TE+Twz3zki7I/g/KXdghIbGJewrU4yzn08Ebgl6TuZzzuOC6W5es3HX6qsSz3NFShRU0MpucytDmOSpu3yULx3CA9RD1HjVedc0jSjqm6ZzhUjDsFDQhSp/OKj5GQvg0+ZCOixsbtDLAeTTOm/yGi8GyIphIVsgH737FEDV44LJa88IRKK/SetrwT9G/GUIr6vXjoy4GXn7+RboVXnghuSjaoGecwQxL2su3CwAKlO+QFoqxI4FMctHQhQd2OhxTu184jWUlI+rMTBTn1/IQcJHQ6GQdZ7pWiDaNdhTt330efISeiqYwQEzQpTlsURJLhzkEmpCPsERfeIUVyXr6MNuIyp5uziW6xURtt7hhGwzmMNJExfO4Bd9X0ZPqAxdNwAAAABJRU5ErkJggg=="></image></view><view class="user-grade_name"><text>{{ userInfo.grade.name }}</text></view></view><!-- 会员无等级时显示手机号 --><view v-else class="mobile">{{ userInfo.mobile }}</view></view></view><!-- 未登录 --><view v-else class="user-info" @click="handleLogin"><view class="user-avatar"><avatar-image :width="100" /></view><view class="user-content"><view class="nick-name">未登录</view><view class="login-tips">点击登录账号</view></view></view></view><!-- 绑定手机号 --><!-- <view v-if="isLogin && !userInfo.mobile && setting[SettingKeyEnum.REGISTER.value].isManualBind" class="my-mobile"@click="handleBindMobile()"><view class="info">点击绑定手机号,确保账户安全</view><view class="btn-bind">去绑定</view></view> --><!-- 我的钱包 --><view v-if="$checkModules(['market-recharge', 'market-points', 'market-coupon'])" class="my-asset"><view class="asset-left flex-box dis-flex flex-x-around"><view v-if="$checkModule('market-recharge')" class="asset-left-item" style="max-width: 200rpx;" @click="onTargetWallet"><view class="item-value dis-flex flex-x-center"><text class="oneline-hide">{{ isLogin ? assets.balance : '--' }}</text></view><view class="item-name dis-flex flex-x-center"><text>账户余额</text></view></view><view v-if="$checkModule('market-points')" class="asset-left-item" @click="onTargetPoints"><view class="item-value dis-flex flex-x-center"><text class="oneline-hide">{{ isLogin ? assets.points : '--' }}</text></view><view class="item-name dis-flex flex-x-center"><text>{{ setting[SettingKeyEnum.POINTS.value].points_name }}</text></view></view><view v-if="$checkModule('market-coupon')" class="asset-left-item" @click="onTargetMyCoupon"><view class="item-value dis-flex flex-x-center"><text class="oneline-hide">{{ isLogin ? assets.coupon : '--' }}</text></view><view class="item-name dis-flex flex-x-center"><text>优惠券</text></view></view></view><view v-if="$checkModule('market-recharge')" class="asset-right"><view class="asset-right-item" @click="onTargetWallet"><view class="item-icon dis-flex flex-x-center"><text class="iconfont icon-qianbao"></text></view><view class="item-name dis-flex flex-x-center"><text>我的钱包</text></view></view></view></view><!-- 绑定手机号 (第2种样式) --><!-- <view class="my-mobile2" @click="handleBindMobile()"><view class="info">点击绑定手机号,确保账户安全</view><view class="btn-bind">去绑定</view></view> --><!-- 订单操作 --><!-- <view class="order-navbar"><view class="order-navbar-item" v-for="(item, index) in orderNavbar" :key="index" @click="onTargetOrder(item)"><view class="item-icon"><text class="iconfont" :class="[`icon-${item.icon}`]"></text></view><view class="item-name">{{ item.name }}</view><view class="item-badge" v-if="item.count && item.count > 0"><text v-if="item.count <= 99" class="text">{{ item.count }}</text><text v-else class="text">99+</text></view></view></view> --><!-- 我的服务 --><view class="my-service"><view class="service-title">我的服务</view><view class="service-content clearfix"><block v-for="(item, index) in service" :key="index"><view v-if="item.type == 'link' && item.enabled" class="service-item" @click="handleService(item)"><view class="item-icon"><text class="iconfont" :class="[`icon-${item.icon}`]"></text></view><view class="item-name">{{ item.name }}</view><view class="item-badge" v-if="item.count && item.count > 0"><text v-if="item.count <= 99" class="text">{{ item.count }}</text><text v-else class="text">99+</text></view></view><!-- 在线客服 --><view v-if="item.type == 'contact' && item.enabled" class="service-item"><customer-btn><view class="item-icon"><text class="iconfont" :class="[`icon-${item.icon}`]"></text></view><view class="item-name">{{ item.name }}</view></customer-btn></view></block></view></view><!-- 退出登录 --><view v-if="isLogin" class="my-logout"><view class="logout-btn" @click="handleLogout()"><text>退出登录</text></view></view></view>
</template><script>import store from '@/store'import { inArray } from '@/utils/util'import AvatarImage from '@/components/avatar-image'import CustomerBtn from '@/components/customer-btn'import { setCartTabBadge } from '@/core/app'import SettingKeyEnum from '@/common/enum/setting/Key'import StoreModel from '@/common/model/Store'import SettingModel from '@/common/model/Setting'import * as UserApi from '@/api/user'import * as OrderApi from '@/api/order'import { checkLogin, filterModules } from '@/core/app'// 订单操作const orderNavbar = [{ id: 'all', name: '全部订单', icon: 'qpdingdan' },{ id: 'payment', name: '待支付', icon: 'daifukuan', count: 0 },{ id: 'delivery', name: '待发货', icon: 'daifahuo', count: 0 },{ id: 'received', name: '待收货', icon: 'daishouhuo', count: 0 },]/*** 我的服务* id: 标识; name: 标题名称; icon: 图标; type 类型(link和button); url: 跳转的链接*/const service = [// { id: 'address', name: '收货地址', icon: 'shouhuodizhi', type: 'link', url: 'pages/address/index' },{ id: 'coupon', name: '领券中心', icon: 'lingquan', type: 'link', url: 'pages/coupon/index', moduleKey: 'market-coupon' },{ id: 'myCoupon', name: '优惠券', icon: 'youhuiquan', type: 'link', url: 'pages/my-coupon/index', moduleKey: 'market-coupon' },// { id: 'refund', name: '退换/售后', icon: 'shouhou', type: 'link', url: 'pages/refund/index', count: 0 },{ id: 'contact', name: '在线客服', icon: 'kefu', type: 'contact' },{ id: 'points', name: '我的积分', icon: 'jifen', type: 'link', url: 'pages/points/log', moduleKey: 'market-points' },// { id: 'orderCenter', name: '订单中心', icon: 'order-c', type: 'link', url: 'pages/order/center' },// { id: 'help', name: '我的帮助', icon: 'bangzhu', type: 'link', url: 'pages/help/index', moduleKey: 'content-help' },]export default {components: {AvatarImage,CustomerBtn},data() {return {inArray,// 枚举类SettingKeyEnum,// 正在加载isLoading: true,// 首次加载isFirstload: true,// 是否已登录isLogin: false,// 系统设置setting: {},// 当前用户信息userInfo: {},// 账户资产assets: { balance: '--', points: '--', coupon: '--' },// 我的服务service,// 订单操作orderNavbar,// 当前用户待处理的订单数量todoCounts: { payment: 0, deliver: 0, received: 0 }}},/*** 生命周期函数--监听页面显示*/onLoad(options) {},/*** 生命周期函数--监听页面显示*/onShow(options) {this.onRefreshPage()},methods: {// 刷新页面onRefreshPage() {// 更新购物车角标setCartTabBadge()// 判断是否已登录this.isLogin = checkLogin()// 获取页面数据this.getPageData()},// 获取页面数据getPageData(callback) {const app = thisapp.isLoading = truePromise.all([app.getSetting(), app.getUserInfo(), app.getUserAssets(), app.getTodoCounts()]).then(result => {app.isFirstload = false// 初始化我的服务数据app.initService()// 初始化订单操作数据app.initOrderTabbar()// 执行回调函数callback && callback()}).catch(err => console.log('catch', err)).finally(() => app.isLoading = false)},// 初始化我的服务数据async initService() {const app = thisconst isShowCustomerBtn = await SettingModel.isShowCustomerBtn()const newService = []service.forEach(item => {// 默认开启item.enabled = true// 我的积分if (item.id === 'points') {item.name = '我的' + app.setting[SettingKeyEnum.POINTS.value].points_name}// 企业微信客服if (item.id === 'contact' && !isShowCustomerBtn) {item.enabled = false}// 数据角标if (item.count != undefined) {item.count = app.todoCounts[item.id]}newService.push(item)})app.service = filterModules(newService)},// 初始化订单操作数据initOrderTabbar() {const app = thisconst newOrderNavbar = []orderNavbar.forEach(item => {if (item.count != undefined) {item.count = app.todoCounts[item.id]}newOrderNavbar.push(item)})app.orderNavbar = newOrderNavbar},// 获取商城设置getSetting() {const app = thisreturn new Promise((resolve, reject) => {SettingModel.data().then(setting => {app.setting = settingresolve(setting)}).catch(reject)})},// 获取当前用户信息getUserInfo() {const app = thisreturn new Promise((resolve, reject) => {!app.isLogin ? resolve(null) : UserApi.info({}, { load: app.isFirstload }).then(result => {app.userInfo = result.data.userInforesolve(app.userInfo)}).catch(err => {if (err.result && err.result.status == 401) {app.isLogin = falseresolve(null)} else {reject(err)}})})},// 获取账户资产getUserAssets() {const app = thisreturn new Promise((resolve, reject) => {!app.isLogin ? resolve(null) : UserApi.assets({}, { load: app.isFirstload }).then(result => {app.assets = result.data.assetsresolve(app.assets)}).catch(err => {if (err.result && err.result.status == 401) {app.isLogin = falseresolve(null)} else {reject(err)}})})},// 获取当前用户待处理的订单数量getTodoCounts() {const app = thisreturn new Promise((resolve, reject) => {!app.isLogin ? resolve(null) : OrderApi.todoCounts({}, { load: app.isFirstload }).then(result => {app.todoCounts = result.data.countsresolve(app.todoCounts)}).catch(err => {if (err.result && err.result.status == 401) {app.isLogin = falseresolve(null)} else {reject(err)}})})},// 跳转到登录页handleLogin() {!this.isLogin && this.$navTo('pages/login/index')},// 跳转到绑定手机号页面handleBindMobile() {this.$navTo('pages/user/bind/index')},// 跳转到修改个人信息页handlePersonal() {this.$navTo('pages/user/personal/index')},// 退出登录handleLogout() {const app = thisuni.showModal({title: '友情提示',content: '您确定要退出登录吗?',success(res) {if (res.confirm) {store.dispatch('Logout', {}).then(result => app.onRefreshPage())}}})},// 跳转到钱包页面onTargetWallet() {this.$navTo('pages/wallet/index')},// 跳转到订单页onTargetOrder(item) {this.$navTo('pages/order/index', { dataType: item.id })},// 跳转到我的积分页面onTargetPoints() {this.$navTo('pages/points/log')},// 跳转到我的优惠券页onTargetMyCoupon() {this.$navTo('pages/my-coupon/index')},// 跳转到服务页面handleService({ url }) {this.$navTo(url)}},/*** 下拉刷新*/onPullDownRefresh() {// 获取首页数据this.getPageData(() => {uni.stopPullDownRefresh()})},}
</script><style lang="scss" scoped>.container {padding-bottom: 60rpx;}// 页面头部.main-header {// background-color: #FBF7EF;position: relative;width: 100%;height: 280rpx;background-size: 100% 100%;overflow: hidden;display: flex;align-items: center;padding-left: 30rpx;.bg-image {position: absolute;top: 0;left: 0;width: 100%;height: 100%;z-index: 0;}.user-info {display: flex;height: 100rpx;z-index: 1;.user-content {display: flex;flex-direction: column;justify-content: center;margin-left: 30rpx;color: #c59a46;.nick-name {font-size: 34rpx;font-weight: bold;max-width: 300rpx;}.mobile {margin-top: 15rpx;font-size: 28rpx;}.user-grade {align-self: baseline;display: flex;align-items: center;background: #3c3c3c;margin-top: 12rpx;border-radius: 10rpx;padding: 4rpx 12rpx;.user-grade_icon .image {display: block;width: 32rpx;height: 32rpx;}.user-grade_name {margin-left: 5rpx;font-size: 26rpx;color: #EEE0C3;}}.login-tips {margin-top: 12rpx;font-size: 30rpx;}}}}// 角标组件.item-badge {position: absolute;top: 0;right: 55rpx;// background: $main-bg;background: #fa2209;color: #fff;border-radius: 100%;min-width: 38rpx;height: 38rpx;display: flex;justify-content: center;align-items: center;padding: 1rpx;font-size: 24rpx;}// 我的钱包.my-asset {display: flex;background: #fff;padding: 40rpx 0;.asset-right {width: 200rpx;border-left: 1rpx solid #eee;}.asset-right-item {text-align: center;color: #545454;.item-icon {font-size: 44rpx;}.item-name {margin-top: 14rpx;font-size: 28rpx;}}.asset-left-item {max-width: 183rpx;text-align: center;color: #666;padding: 0 16rpx;.item-value {font-size: 34rpx;color: $main-bg;}.item-name {margin-top: 14rpx;font-size: 28rpx;}}}// 订单操作.order-navbar {display: flex;margin: 20rpx auto 20rpx auto;padding: 20rpx 0 26rpx 0;width: 94%;box-shadow: 0 1rpx 5rpx 0px rgba(0, 0, 0, 0.05);font-size: 30rpx;border-radius: 5rpx;background: #fff;&-item {position: relative;width: 25%;.item-icon {text-align: center;margin: 0 auto;padding: 10rpx 0;color: #545454;font-size: 44rpx;}.item-name {font-size: 28rpx;color: #545454;text-align: center;margin-right: 10rpx;}}}// 我的服务.my-service {margin: 22rpx auto 22rpx auto;padding: 22rpx 0;width: 94%;box-shadow: 0 1rpx 5rpx 0px rgba(0, 0, 0, 0.05);border-radius: 5rpx;background: #fff;.service-title {padding-left: 24rpx;margin-bottom: 20rpx;font-size: 30rpx;}.service-content {margin-bottom: -20rpx;.service-item {position: relative;width: 25%;float: left;margin-bottom: 30rpx;.item-icon {text-align: center;margin: 0 auto;padding: 14rpx 0;color: $main-bg;font-size: 44rpx;}.item-name {font-size: 28rpx;color: #545454;text-align: center;}}}}// 退出登录.my-logout {display: flex;justify-content: center;margin-top: 50rpx;.logout-btn {width: 60%;margin: 0 auto;font-size: 28rpx;color: #616161;border-radius: 20rpx;border: 1px solid #dcdcdc;padding: 16rpx 0;text-align: center;}}// 绑定手机号 样式1.my-mobile {display: flex;justify-content: space-between;align-items: center;padding: 16rpx 40rpx;background: #FCEBD1;.info {color: #cd8c0c;font-size: 28rpx;}.btn-bind {padding: 8rpx 24rpx;background-color: #EAB766;color: #fff;border-radius: 30rpx;font-size: 26rpx;text-align: center;}}// 绑定手机号 样式2.my-mobile2 {display: flex;justify-content: space-between;align-items: center;margin: 20rpx auto 20rpx auto;padding: 12rpx 40rpx;width: 94%;box-shadow: 0 1rpx 5rpx 0px rgba(0, 0, 0, 0.05);font-size: 30rpx;border-radius: 5rpx;background: #fff;.info {// color: #cd8c0c;font-size: 26rpx;}.btn-bind {padding: 8rpx 24rpx;background-color: #EAB766;color: #fff;border-radius: 30rpx;font-size: 26rpx;text-align: center;}}
</style>

三、项目总结

由于篇幅原因,更多信息和源码可直接联系本人微信(red_tea_v2),代码和服务部署可以提供技术支持,其他问题可直接在文章下面评论。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/786672.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《Programming from the Ground Up》阅读笔记:p103-p116

《Programming from the Ground Up》学习第7天,p103-p116总结,总计14页。 一、技术总结 1.读写文件 (1)linux.s linux.s: #file name:linux.s# system call numbers(按数字大小排列,方便查看) .equ SYS_READ, 0 .equ SYS_WRITE, 1 .equ SYS_OPEN, 2 .equ SYS_CLOSE, 3 .equ …

控件与布局

1.控件的分类:主要要6大类一.布局控件:可以容纳多个控件或者嵌套其他布局控件,用于在UI上组织和排列控件。Grid、StackPanel、DockPanel等都属于此类,他们拥有共同的父类Panel二.内容控件:只能容纳一个其他控件或者布局控件作为他的内容。Window、Button等都属于此类,因为…

第7篇:在虚拟机 centos7上搭建jira管理工具

本文详细介绍了如何在CentOS7系统上下载配置Jira,包括创建文件夹、下载安装包、解压、修改配置文件以及设置JVM和MySQL环境。同时,文章还涉及了JDK1.8的安装,数据库的创建,以及Jira的破解步骤,包括替换特定jar文件和配置数据库连接。最后,文章提到了启动Jira服务并进行汉…

最近遇到的一些奇奇怪怪奇技淫巧

然后我CF上绿了————DaisySunchaser要多思考。构造——从哪里入手?CF交互指南要多注意。 我的最初想法:当我查看了他使用了冰茶几的代码: #include<bits/stdc++.h> #define ll long long #define N 200005 #define mp make_pair using namespace std; int T,n,u[N]…

Qt/C++音视频开发81-采集本地麦克风/本地摄像头带麦克风/桌面采集和麦克风/本地设备和桌面推流

一、前言 随着直播的兴起,采集本地摄像头和麦克风进行直播推流,也是一个刚需,最简单的做法是直接用ffmpeg命令行采集并推流,这种方式简单粗暴,但是不能实时预览画面,而且不方便加上一些特殊要求。之前就已经打通了音视频文件和视频流的采集,那是不是可以简单点的方式就能…

如何缩短微信文章链接长度

有时候,我们想把微信公众号的文章发到其他平台上,这时候就需要复制文章的链接。有时候,我们想把微信公众号的文章发到其他平台上,这时候就需要复制文章的链接。 ‍ 手机端复制方式如下: ​ ‍ 微信对于短网址的优化 以前,微信公众号文章的链接特别长。但在 2016 年末,微…

verilog代码与设计总结

Verilog编码风格及设计建议相比于case语句,casez语句将z态看做不关心,casex语句将z态和x态看做不关心。并且所有case类型语句均没有优先级。 锁存器是组合逻辑产生的,一般没有复位端,所以根据其所存特性,在上电的时候没法确定其初始状态,因此正常情况下要避免使用。 组合…

【Azure Logic App】在逻辑应用中开启或关闭一个工作流是否会对其它工作流产生影响呢?

问题描述 使用标准版的Azure Logic App服务,可以创建多个工作流(workflow),如果在启用/禁用其它的工作流时,是否会对正在运行其它工作流造成影响呢? 问题解答 在实际的测验中,我们得到的答案是:会造成影响!在Disabled/Enabled同一个Logic App中的Workflow时,正在运行的…

开源|一款企业应用定制化开发平台,支持企业OA协同办公类信息化系统的建设和开发

前言 在数字化转型的浪潮中,企业面临着多样化的信息系统建设需求。现有的软件系统往往存在定制化程度低、开发周期长、成-本高等问题。此外,随着企业规模的扩大和业务的复杂化,传统的软件系统难以满足灵活多变的业务需 为了解-决这些痛点,企业需要一款能够快速定制、灵活扩…

暑假集训总结 2024

暑假集训总结 2024考试情况:因为身体原因,只参加了29场,表格中标红的是题没改完的 越往后分越低,改题的量也越少,排名和分跟心电图差不多 分低和改题量少不只是因为题难,也有后来状态越来越差,改题的时候很困的原因 为什么排名和分是这样的,主要是心态和答题策略,做不…

Tesla 开发者 API 指南:通过Http发送命令

前言 特斯拉提供两种与汽车通信的方式。一种是使用 API 通过互联网,另一种是使用 BLE 连接。 特斯拉现在只能接受车辆命令 SDK (vehicle command SDK)方式发送命令,该 SDK 使用 Http-Proxy 服务器将命令转发给车辆。除了验证 oAuth 令牌之外,特斯拉正在转向一种更安全的方式…