fix: 系统名称修改、商品详情回显修复,logo,环境修改

main
wx-jincw 2 weeks ago
parent 13f4167e37
commit 45423ea6a7

@ -10,7 +10,7 @@ VITE_APP_ENV = 'development'
VITE_APP_MP_APPID = 'wx42bbe857570c5b40'
# 统一接口域名
VITE_APP_BASE_API = 'http://127.0.0.1:8086'
VITE_APP_BASE_API = 'https://wy6.test.jiutianda.cn'
# 图片域名
VITE_APP_RESOURCES_URL = 'https://img.mall4j.com/'

@ -1,99 +1,99 @@
{
"name" : "",
"appid" : "__UNI__2CF44C6",
"description" : "",
"versionName" : "1.0.0",
"versionCode" : "100",
"transformPx" : false,
/* 5+App */
"app-plus" : {
"compatible" : {
"ignoreVersion" : true //trueHBuilderX1.9.0
},
"usingComponents" : true,
"nvueStyleCompiler" : "uni-app",
"compilerVersion" : 3,
"splashscreen" : {
"alwaysShowBeforeRender" : true,
"waiting" : true,
"autoclose" : true,
"delay" : 0
},
/* */
"modules" : {
"Camera" : {},
"LivePusher" : {}
},
/* */
"distribute" : {
/* android */
"android" : {
"permissions" : [
"<uses-feature android:name=\"android.hardware.camera\"/>",
"<uses-feature android:name=\"android.hardware.camera.autofocus\"/>",
"<uses-permission android:name=\"android.permission.ACCESS_NETWORK_STATE\"/>",
"<uses-permission android:name=\"android.permission.ACCESS_WIFI_STATE\"/>",
"<uses-permission android:name=\"android.permission.CAMERA\"/>",
"<uses-permission android:name=\"android.permission.CHANGE_NETWORK_STATE\"/>",
"<uses-permission android:name=\"android.permission.CHANGE_WIFI_STATE\"/>",
"<uses-permission android:name=\"android.permission.FLASHLIGHT\"/>",
"<uses-permission android:name=\"android.permission.GET_ACCOUNTS\"/>",
"<uses-permission android:name=\"android.permission.MOUNT_UNMOUNT_FILESYSTEMS\"/>",
"<uses-permission android:name=\"android.permission.READ_LOGS\"/>",
"<uses-permission android:name=\"android.permission.READ_PHONE_STATE\"/>",
"<uses-permission android:name=\"android.permission.RECORD_AUDIO\"/>",
"<uses-permission android:name=\"android.permission.VIBRATE\"/>",
"<uses-permission android:name=\"android.permission.WAKE_LOCK\"/>",
"<uses-permission android:name=\"android.permission.WRITE_SETTINGS\"/>"
],
"abiFilters" : [ "armeabi-v7a", "arm64-v8a", "x86" ]
}
}
},
/* */
"mp-weixin" : {
"appid" : "wx6fa71e69231a4fa4",
"setting" : {
"urlCheck" : false
},
"usingComponents" : true,
"permission" : {
"scope.userLocation" : {
"desc" : "你的位置信息将用于地址信息新增、修改以及获取附近门店"
}
},
"requiredPrivateInfos" : [ "getLocation", "chooseLocation" ]
},
"h5" : {
"title" : "",
"domain" : "https://mini-h5.mall4j.com",
"router" : {
"mode" : "history"
},
"uniStatistics" : {
"enable" : false
},
"optimization" : {
"treeShaking" : {
"enable" : false
}
},
"template" : "index.html",
"devServer" : {
"disableHostCheck" : true,
"port" : 80
},
"sdkConfigs" : {
"maps" : {
"qqmap" : {
// h5ip
"key" : ""
}
}
}
},
"uniStatistics" : {
"enable" : false
},
"vueVersion" : "3"
{
"name": "甄味馆",
"appid": "__UNI__6140E53",
"description": "",
"versionName": "1.0.0",
"versionCode": "100",
"transformPx": false,
/* 5+App */
"app-plus": {
"compatible": {
"ignoreVersion": true //trueHBuilderX1.9.0
},
"usingComponents": true,
"nvueStyleCompiler": "uni-app",
"compilerVersion": 3,
"splashscreen": {
"alwaysShowBeforeRender": true,
"waiting": true,
"autoclose": true,
"delay": 0
},
/* */
"modules": {
"Camera": {},
"LivePusher": {}
},
/* */
"distribute": {
/* android */
"android": {
"permissions": [
"<uses-feature android:name=\"android.hardware.camera\"/>",
"<uses-feature android:name=\"android.hardware.camera.autofocus\"/>",
"<uses-permission android:name=\"android.permission.ACCESS_NETWORK_STATE\"/>",
"<uses-permission android:name=\"android.permission.ACCESS_WIFI_STATE\"/>",
"<uses-permission android:name=\"android.permission.CAMERA\"/>",
"<uses-permission android:name=\"android.permission.CHANGE_NETWORK_STATE\"/>",
"<uses-permission android:name=\"android.permission.CHANGE_WIFI_STATE\"/>",
"<uses-permission android:name=\"android.permission.FLASHLIGHT\"/>",
"<uses-permission android:name=\"android.permission.GET_ACCOUNTS\"/>",
"<uses-permission android:name=\"android.permission.MOUNT_UNMOUNT_FILESYSTEMS\"/>",
"<uses-permission android:name=\"android.permission.READ_LOGS\"/>",
"<uses-permission android:name=\"android.permission.READ_PHONE_STATE\"/>",
"<uses-permission android:name=\"android.permission.RECORD_AUDIO\"/>",
"<uses-permission android:name=\"android.permission.VIBRATE\"/>",
"<uses-permission android:name=\"android.permission.WAKE_LOCK\"/>",
"<uses-permission android:name=\"android.permission.WRITE_SETTINGS\"/>"
],
"abiFilters": ["armeabi-v7a", "arm64-v8a", "x86"]
}
}
},
/* */
"mp-weixin": {
"appid": "wx6fa71e69231a4fa4",
"setting": {
"urlCheck": false
},
"usingComponents": true,
"permission": {
"scope.userLocation": {
"desc": "你的位置信息将用于地址信息新增、修改以及获取附近门店"
}
},
"requiredPrivateInfos": ["getLocation", "chooseLocation"]
},
"h5": {
"title": "甄味馆",
"domain": "https://mini-h5.mall4j.com",
"router": {
"mode": "history"
},
"uniStatistics": {
"enable": false
},
"optimization": {
"treeShaking": {
"enable": false
}
},
"template": "index.html",
"devServer": {
"disableHostCheck": true,
"port": 80
},
"sdkConfigs": {
"maps": {
"qqmap": {
// h5ip
"key": ""
}
}
}
},
"uniStatistics": {
"enable": false
},
"vueVersion": "3"
}

@ -1,196 +1,194 @@
{
"pages": [
{
"path": "pages/index/index",
"style": {
"backgroundTextStyle": "dark",
"navigationBarBackgroundColor": "#fff",
"navigationBarTextStyle": "black",
"enablePullDownRefresh": true,
"navigationBarTitleText": "mall4j"
}
},
{
"path": "pages/user/user",
"style": {
"navigationBarTitleText": "个人中心"
}
},
{
"path": "pages/basket/basket",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "购物车",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/category/category",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "分类商品",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/sub-category/sub-category"
},
{
"path": "pages/search-page/search-page",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "搜索",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/delivery-address/delivery-address",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "收货地址",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/editAddress/editAddress",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "编辑收货地址",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/orderList/orderList",
"style": {
"backgroundTextStyle": "light",
"navigationBarTitleText": "订单列表",
"navigationBarTextStyle": "black",
"navigationBarBackgroundColor": "#fafafa"
}
},
{
"path": "pages/order-detail/order-detail",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "订单详情",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/submit-order/submit-order",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "提交订单",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/express-delivery/express-delivery",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "物流查询",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/pay-result/pay-result",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "支付结果",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/search-prod-show/search-prod-show",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "搜索结果",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/prod/prod",
"style": {
"navigationBarTitleText": "商品详情"
}
},
{
"path": "pages/prod-classify/prod-classify",
"style": {
"onReachBottomDistance": 0
}
},
{
"path": "pages/recent-news/recent-news",
"style": {
"backgroundTextStyle": "light",
"navigationBarTitleText": "最新公告",
"navigationBarTextStyle": "black",
"navigationBarBackgroundColor": "#fafafa"
}
},
{
"path": "pages/news-detail/news-detail",
"style": {
"backgroundTextStyle": "light",
"navigationBarTitleText": "最新公告",
"navigationBarTextStyle": "black",
"navigationBarBackgroundColor": "#fafafa"
}
},
{
"path": "pages/accountLogin/accountLogin"
},
{
"path": "pages/register/register"
}
],
"tabBar": {
"selectedColor": "#3a86b9",
"color": "#b8b8b8",
"list": [
{
"pagePath": "pages/index/index",
"text": "首页",
"iconPath": "/static/images/tabbar/homepage.png",
"selectedIconPath": "/static/images/tabbar/homepage-sel.png"
},
{
"pagePath": "pages/category/category",
"text": "分类",
"iconPath": "/static/images/tabbar/category.png",
"selectedIconPath": "/static/images/tabbar/category-sel.png"
},
{
"pagePath": "pages/basket/basket",
"text": "购物车",
"iconPath": "/static/images/tabbar/basket.png",
"selectedIconPath": "/static/images/tabbar/basket-sel.png"
},
{
"pagePath": "pages/user/user",
"text": "我的",
"iconPath": "/static/images/tabbar/user.png",
"selectedIconPath": "/static/images/tabbar/user-sel.png"
}
]
},
"sitemapLocation": "sitemap.json",
"globalStyle": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "WeChat",
"navigationBarTextStyle": "black"
},
"subPackages": []
{
"pages": [{
"path": "pages/index/index",
"style": {
"backgroundTextStyle": "dark",
"navigationBarBackgroundColor": "#fff",
"navigationBarTextStyle": "black",
"enablePullDownRefresh": true,
"navigationBarTitleText": "甄味馆"
}
},
{
"path": "pages/user/user",
"style": {
"navigationBarTitleText": "个人中心"
}
},
{
"path": "pages/basket/basket",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "购物车",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/category/category",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "分类商品",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/sub-category/sub-category"
},
{
"path": "pages/search-page/search-page",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "搜索",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/delivery-address/delivery-address",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "收货地址",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/editAddress/editAddress",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "编辑收货地址",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/orderList/orderList",
"style": {
"backgroundTextStyle": "light",
"navigationBarTitleText": "订单列表",
"navigationBarTextStyle": "black",
"navigationBarBackgroundColor": "#fafafa"
}
},
{
"path": "pages/order-detail/order-detail",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "订单详情",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/submit-order/submit-order",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "提交订单",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/express-delivery/express-delivery",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "物流查询",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/pay-result/pay-result",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "支付结果",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/search-prod-show/search-prod-show",
"style": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "搜索结果",
"navigationBarTextStyle": "black"
}
},
{
"path": "pages/prod/prod",
"style": {
"navigationBarTitleText": "商品详情"
}
},
{
"path": "pages/prod-classify/prod-classify",
"style": {
"onReachBottomDistance": 0
}
},
{
"path": "pages/recent-news/recent-news",
"style": {
"backgroundTextStyle": "light",
"navigationBarTitleText": "最新公告",
"navigationBarTextStyle": "black",
"navigationBarBackgroundColor": "#fafafa"
}
},
{
"path": "pages/news-detail/news-detail",
"style": {
"backgroundTextStyle": "light",
"navigationBarTitleText": "最新公告",
"navigationBarTextStyle": "black",
"navigationBarBackgroundColor": "#fafafa"
}
},
{
"path": "pages/accountLogin/accountLogin"
},
{
"path": "pages/register/register"
}
],
"tabBar": {
"selectedColor": "#3a86b9",
"color": "#b8b8b8",
"list": [{
"pagePath": "pages/index/index",
"text": "首页",
"iconPath": "/static/images/tabbar/homepage.png",
"selectedIconPath": "/static/images/tabbar/homepage-sel.png"
},
{
"pagePath": "pages/category/category",
"text": "分类",
"iconPath": "/static/images/tabbar/category.png",
"selectedIconPath": "/static/images/tabbar/category-sel.png"
},
{
"pagePath": "pages/basket/basket",
"text": "购物车",
"iconPath": "/static/images/tabbar/basket.png",
"selectedIconPath": "/static/images/tabbar/basket-sel.png"
},
{
"pagePath": "pages/user/user",
"text": "我的",
"iconPath": "/static/images/tabbar/user.png",
"selectedIconPath": "/static/images/tabbar/user-sel.png"
}
]
},
"sitemapLocation": "sitemap.json",
"globalStyle": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "WeChat",
"navigationBarTextStyle": "black"
},
"subPackages": []
}

@ -5,12 +5,10 @@
}
image {
display: block;
width: 150rpx;
width: 180rpx;
height: 150rpx;
margin: auto;
border-radius: 50%;
width: 150rpx;
height: 150rpx;
// border-radius: 50%;
margin-bottom: 8%;
}
.login-form {

@ -1,507 +1,399 @@
<template>
<view class="container">
<view class="bg-sear">
<view class="scrolltop">
<view
class="section"
@tap="toSearchPage"
>
<image
src="@/static/images/icon/search.png"
class="search-img"
/>
<text class="placeholder">
搜索
</text>
</view>
</view>
</view>
<view class="content">
<!-- swiper -->
<swiper
:autoplay="autoplay"
:indicator-color="indicatorColor"
:interval="interval"
:duration="duration"
:indicator-active-color="indicatorActiveColor + ' '"
:circular="true"
class="pic-swiper"
indicator-dots
previous-margin="20rpx"
next-margin="20rpx"
>
<block
v-for="(item, index) in indexImgs"
:key="index"
>
<swiper-item class="banner-item">
<view class="img-box">
<image
:src="item.imgUrl"
:data-prodid="item.relation"
class="banner"
@tap="toProdPage"
/>
</view>
</swiper-item>
</block>
</swiper>
<!-- end swiper -->
<view class="cat-item">
<view
class="item"
data-sts="1"
@tap="toClassifyPage"
>
<image src="@/static/images/icon/newProd.png" />
<text>新品推荐</text>
</view>
<view
class="item"
data-sts="1"
@tap="toClassifyPage"
>
<image src="@/static/images/icon/timePrice.png" />
<text>限时特惠</text>
</view>
<view
class="item"
data-sts="3"
@tap="toClassifyPage"
>
<image src="@/static/images/icon/neweveryday.png" />
<text>每日疯抢</text>
</view>
<view
class="item"
@tap="toCouponCenter"
>
<image src="@/static/images/icon/newprods.png" />
<text>领优惠券</text>
</view>
</view>
<!-- 消息播放 -->
<view
v-if="news && news.length"
class="message-play"
@tap="onNewsPage"
>
<image
src="@/static/images/icon/horn.png"
class="hornpng"
/>
<swiper
:vertical="true"
:autoplay="true"
:circular="true"
duration="1000"
class="swiper-cont"
>
<block
v-for="(item, index) in news"
:key="index"
>
<swiper-item class="items">
{{ item.title }}
</swiper-item>
</block>
</swiper>
<text class="arrow" />
</view>
</view>
<view
v-if="updata"
class="updata"
>
<block
v-for="(item, index) in taglist"
:key="index"
>
<!-- 每日上新 -->
<view
v-if="item.style==='2' && item.prods && item.prods.length"
class="up-to-date"
>
<view class="title">
<text>{{ item.title }}</text>
<view
class="more-prod-cont"
data-sts="0"
:data-id="item.id"
:data-title="item.title"
@tap="toClassifyPage"
>
<text class="more">
查看更多
</text>
</view>
</view>
<view class="item-cont">
<block
v-for="(prod, index2) in item.prods"
:key="index2"
>
<view
class="prod-item"
:data-prodid="prod.prodId"
@tap="toProdPage"
>
<view>
<view class="imagecont">
<img-show
:src="prod.pic"
:class-list="['prodimg']"
/>
</view>
<view class="prod-text">
{{ prod.prodName }}
</view>
<view class="price">
<text class="symbol">
</text>
<text class="big-num">
{{ wxs.parsePrice(prod.price)[0] }}
</text>
<text class="small-num">
.{{ wxs.parsePrice(prod.price)[1] }}
</text>
</view>
</view>
</view>
</block>
</view>
</view>
<!-- 商城热卖 -->
<view
v-if="item.style==='1' && item.prods && item.prods.length"
class="hot-sale"
>
<view class="title">
<text>{{ item.title }}</text>
<view
class="more-prod-cont"
data-sts="0"
:data-id="item.id"
:data-title="item.title"
@tap="toClassifyPage"
>
<text class="more">
更多
</text>
<text class="arrow" />
</view>
</view>
<view class="hotsale-item-cont">
<block
v-for="(prod, index2) in item.prods"
:key="index2"
>
<view
class="prod-items"
:data-prodid="prod.prodId"
@tap="toProdPage"
>
<view class="hot-imagecont">
<img-show
:src="prod.pic"
:class-list="['hotsaleimg']"
/>
</view>
<view class="hot-text">
<view class="hotprod-text">
{{ prod.prodName }}
</view>
<view class="prod-info">
{{ prod.brief }}
</view>
<view class="prod-text-info">
<view class="price">
<text class="symbol">
</text>
<text class="big-num">
{{ wxs.parsePrice(prod.price)[0] }}
</text>
<text class="small-num">
.{{ wxs.parsePrice(prod.price)[1] }}
</text>
</view>
<image
src="@/static/images/tabbar/basket-sel.png"
class="basket-img"
/>
</view>
</view>
</view>
</block>
</view>
</view>
<!-- 更多宝贝 -->
<view
v-if="item.style==='0' && item.prods && item.prods.length"
class="more-prod"
>
<view class="title">
{{ item.title }}
</view>
<view class="prod-show">
<block
v-for="(prod, index2) in item.prods"
:key="index2"
>
<view
class="show-item"
:data-prodid="prod.prodId"
@tap="toProdPage"
>
<view class="more-prod-pic">
<img-show
:src="prod.pic"
:class-list="['more-pic']"
/>
</view>
<view class="prod-text-right">
<view class="prod-text more">
{{ prod.prodName }}
</view>
<view class="prod-info">
{{ prod.brief }}
</view>
<view class="b-cart">
<view class="price">
<text class="symbol">
</text>
<text class="big-num">
{{ wxs.parsePrice(prod.price)[0] }}
</text>
<text class="small-num">
.{{ wxs.parsePrice(prod.price)[1] }}
</text>
</view>
<image
src="@/static/images/tabbar/basket-sel.png"
class="basket-img"
@tap.stop="addToCart(prod)"
/>
</view>
</view>
</view>
</block>
</view>
</view>
</block>
</view>
</view>
</template>
<script setup>
const wxs = number()
const indicatorColor = ref('#d1e5fb')
const indicatorActiveColor = ref('#1b7dec')
const autoplay = ref(true)
const interval = ref(2000)
const duration = ref(1000)
const indexImgs = ref([])
const seq = ref(0)
const news = ref([])
const taglist = ref([])
const updata = ref(true)
onLoad(() => {
getAllData()
})
onShow(() => {
// #ifdef MP-WEIXIN
uni.getSetting({
success (res) {
if (!res.authSetting['scope.userInfo']) {
uni.navigateTo({
url: '/pages/login/login'
})
}
}
})
// #endif
http.getCartCount() //
})
onPullDownRefresh(() => {
//
setTimeout(() => {
getAllData()
uni.stopPullDownRefresh() //
}, 100)
})
const getAllData = () => {
http.getCartCount()//
getIndexImgs()
getNoticeList()
getTag()
}
const toProdPage = (e) => {
const prodid = e.currentTarget.dataset.prodid
if (prodid) {
uni.navigateTo({
url: '/pages/prod/prod?prodid=' + prodid
})
}
}
/**
* 加入购物车
* @param item
*/
const addToCart = (item) => {
uni.showLoading({
mask: true
})
http.request({
url: '/prod/prodInfo',
method: 'GET',
data: {
prodId: item.prodId
}
})
.then(({ data }) => {
http.request({
url: '/p/shopCart/changeItem',
method: 'POST',
data: {
basketId: 0,
count: 1,
prodId: data.prodId,
shopId: data.shopId,
skuId: data.skuList[0].skuId
}
})
.then(() => {
uni.hideLoading()
http.getCartCount() //
uni.showToast({
title: '加入购物车成功',
icon: 'none'
})
})
})
}
const toCouponCenter = () => {
uni.showToast({
icon: 'none',
title: '该功能未开源'
})
}
/**
* 跳转搜索页
*/
const toSearchPage = () => {
uni.navigateTo({
url: '/pages/search-page/search-page'
})
}
/**
* 跳转商品活动页面
* @param e
*/
const toClassifyPage = (e) => {
let url = '/pages/prod-classify/prod-classify?sts=' + e.currentTarget.dataset.sts
const id = e.currentTarget.dataset.id
const title = e.currentTarget.dataset.title
if (id) {
url += '&tagid=' + id + '&title=' + title
}
uni.navigateTo({
url
})
}
/**
* 跳转公告列表页面
*/
const onNewsPage = () => {
uni.navigateTo({
url: '/pages/recent-news/recent-news'
})
}
/**
* 加载轮播图
*/
const getIndexImgs = () => {
http.request({
url: '/indexImgs',
method: 'GET',
data: {}
})
.then(({ data }) => {
indexImgs.value = data
seq.value = data
})
}
const getNoticeList = () => {
//
http.request({
url: '/shop/notice/topNoticeList',
method: 'GET',
data: {}
})
.then(({ data }) => {
news.value = data
})
}
/**
* 加载商品标题分组列表
*/
const getTag = () => {
http.request({
url: '/prod/tag/prodTagList',
method: 'GET',
data: {}
})
.then(({ data }) => {
taglist.value = data
for (let i = 0; i < data.length; i++) {
updata.value = false
updata.value = true
getTagProd(data[i].id, i)
}
})
}
const getTagProd = (id, index) => {
http.request({
url: '/prod/prodListByTagId',
method: 'GET',
data: {
tagId: id,
size: 6
}
})
.then(({ data }) => {
updata.value = false
updata.value = true
const taglistParam = taglist.value
taglistParam[index].prods = data.records
taglist.value = taglistParam
})
}
</script>
<style scoped lang="scss">
@use './index.scss';
<template>
<view class="container">
<view class="bg-sear">
<view class="scrolltop">
<view class="section" @tap="toSearchPage">
<image src="@/static/images/icon/search.png" class="search-img" />
<text class="placeholder">
搜索
</text>
</view>
</view>
</view>
<view class="content">
<!-- swiper -->
<swiper :autoplay="autoplay" :indicator-color="indicatorColor" :interval="interval" :duration="duration"
:indicator-active-color="indicatorActiveColor + ' '" :circular="true" class="pic-swiper" indicator-dots
previous-margin="20rpx" next-margin="20rpx">
<block v-for="(item, index) in indexImgs" :key="index">
<swiper-item class="banner-item">
<view class="img-box">
<image :src="item.imgUrl" :data-prodid="item.relation" class="banner" @tap="toProdPage" />
</view>
</swiper-item>
</block>
</swiper>
<!-- end swiper -->
<view class="cat-item">
<view class="item" data-sts="1" @tap="toClassifyPage">
<image src="@/static/images/icon/newProd.png" />
<text>新品推荐</text>
</view>
<view class="item" data-sts="1" @tap="toClassifyPage">
<image src="@/static/images/icon/timePrice.png" />
<text>限时特惠</text>
</view>
<view class="item" data-sts="3" @tap="toClassifyPage">
<image src="@/static/images/icon/neweveryday.png" />
<text>每日疯抢</text>
</view>
<view class="item" @tap="toCouponCenter">
<image src="@/static/images/icon/newprods.png" />
<text>领优惠券</text>
</view>
</view>
<!-- 消息播放 -->
<view v-if="news && news.length" class="message-play" @tap="onNewsPage">
<image src="@/static/images/icon/horn.png" class="hornpng" />
<swiper :vertical="true" :autoplay="true" :circular="true" duration="1000" class="swiper-cont">
<block v-for="(item, index) in news" :key="index">
<swiper-item class="items">
{{ item.title }}
</swiper-item>
</block>
</swiper>
<text class="arrow" />
</view>
</view>
<view v-if="updata" class="updata">
<block v-for="(item, index) in taglist" :key="index">
<!-- 每日上新 -->
<view v-if="item.style==='2' && item.prods && item.prods.length" class="up-to-date">
<view class="title">
<text>{{ item.title }}</text>
<view class="more-prod-cont" data-sts="0" :data-id="item.id" :data-title="item.title" @tap="toClassifyPage">
<text class="more">
查看更多
</text>
</view>
</view>
<view class="item-cont">
<block v-for="(prod, index2) in item.prods" :key="index2">
<view class="prod-item" :data-prodid="prod.prodId" @tap="toProdPage">
<view>
<view class="imagecont">
<img-show :src="prod.pic" :class-list="['prodimg']" />
</view>
<view class="prod-text">
{{ prod.prodName }}
</view>
<view class="price">
<text class="symbol">
</text>
<text class="big-num">
{{ wxs.parsePrice(prod.price)[0] }}
</text>
<text class="small-num">
.{{ wxs.parsePrice(prod.price)[1] }}
</text>
</view>
</view>
</view>
</block>
</view>
</view>
<!-- 商城热卖 -->
<view v-if="item.style==='1' && item.prods && item.prods.length" class="hot-sale">
<view class="title">
<text>{{ item.title }}</text>
<view class="more-prod-cont" data-sts="0" :data-id="item.id" :data-title="item.title" @tap="toClassifyPage">
<text class="more">
更多
</text>
<text class="arrow" />
</view>
</view>
<view class="hotsale-item-cont">
<block v-for="(prod, index2) in item.prods" :key="index2">
<view class="prod-items" :data-prodid="prod.prodId" @tap="toProdPage">
<view class="hot-imagecont">
<img-show :src="prod.pic" :class-list="['hotsaleimg']" />
</view>
<view class="hot-text">
<view class="hotprod-text">
{{ prod.prodName }}
</view>
<view class="prod-info">
{{ prod.brief }}
</view>
<view class="prod-text-info">
<view class="price">
<text class="symbol">
</text>
<text class="big-num">
{{ wxs.parsePrice(prod.price)[0] }}
</text>
<text class="small-num">
.{{ wxs.parsePrice(prod.price)[1] }}
</text>
</view>
<image src="@/static/images/tabbar/basket-sel.png" class="basket-img" />
</view>
</view>
</view>
</block>
</view>
</view>
<!-- 更多宝贝 -->
<view v-if="item.style==='0' && item.prods && item.prods.length" class="more-prod">
<view class="title">
{{ item.title }}
</view>
<view class="prod-show">
<block v-for="(prod, index2) in item.prods" :key="index2">
<view class="show-item" :data-prodid="prod.prodId" @tap="toProdPage">
<view class="more-prod-pic">
<img-show :src="prod.pic" :class-list="['more-pic']" />
</view>
<view class="prod-text-right">
<view class="prod-text more">
{{ prod.prodName }}
</view>
<view class="prod-info">
{{ prod.brief }}
</view>
<view class="b-cart">
<view class="price">
<text class="symbol">
</text>
<text class="big-num">
{{ wxs.parsePrice(prod.price)[0] }}
</text>
<text class="small-num">
.{{ wxs.parsePrice(prod.price)[1] }}
</text>
</view>
<image src="@/static/images/tabbar/basket-sel.png" class="basket-img" @tap.stop="addToCart(prod)" />
</view>
</view>
</view>
</block>
</view>
</view>
</block>
</view>
</view>
</template>
<script setup>
const wxs = number()
const indicatorColor = ref('#d1e5fb')
const indicatorActiveColor = ref('#1b7dec')
const autoplay = ref(true)
const interval = ref(2000)
const duration = ref(1000)
const indexImgs = ref([])
const seq = ref(0)
const news = ref([])
const taglist = ref([])
const updata = ref(true)
onLoad(() => {
getAllData()
})
onShow(() => {
// #ifdef MP-WEIXIN
uni.getSetting({
success(res) {
if (!res.authSetting['scope.userInfo']) {
uni.navigateTo({
url: '/pages/login/login'
})
}
}
})
// #endif
http.getCartCount() //
})
onPullDownRefresh(() => {
//
setTimeout(() => {
getAllData()
uni.stopPullDownRefresh() //
}, 100)
})
const getAllData = () => {
http.getCartCount() //
getIndexImgs()
getNoticeList()
getTag()
}
const toProdPage = (e) => {
const prodid = e.currentTarget.dataset.prodid
if (prodid) {
uni.navigateTo({
url: '/pages/prod/prod?prodid=' + prodid
})
}
}
/**
* 加入购物车
* @param item
*/
const addToCart = (item) => {
uni.showLoading({
mask: true
})
http.request({
url: '/prod/prodInfo',
method: 'GET',
data: {
prodId: item.prodId
}
})
.then(({
data
}) => {
http.request({
url: '/p/shopCart/changeItem',
method: 'POST',
data: {
basketId: 0,
count: 1,
prodId: data.prodId,
shopId: data.shopId,
skuId: data.skuList[0].skuId
}
})
.then(() => {
uni.hideLoading()
http.getCartCount() //
uni.showToast({
title: '加入购物车成功',
icon: 'none'
})
})
})
}
const toCouponCenter = () => {
uni.showToast({
icon: 'none',
title: '功能开发中'
})
}
/**
* 跳转搜索页
*/
const toSearchPage = () => {
uni.navigateTo({
url: '/pages/search-page/search-page'
})
}
/**
* 跳转商品活动页面
* @param e
*/
const toClassifyPage = (e) => {
let url = '/pages/prod-classify/prod-classify?sts=' + e.currentTarget.dataset.sts
const id = e.currentTarget.dataset.id
const title = e.currentTarget.dataset.title
if (id) {
url += '&tagid=' + id + '&title=' + title
}
uni.navigateTo({
url
})
}
/**
* 跳转公告列表页面
*/
const onNewsPage = () => {
uni.navigateTo({
url: '/pages/recent-news/recent-news'
})
}
/**
* 加载轮播图
*/
const getIndexImgs = () => {
http.request({
url: '/indexImgs',
method: 'GET',
data: {}
})
.then(({
data
}) => {
indexImgs.value = data
seq.value = data
})
}
const getNoticeList = () => {
//
http.request({
url: '/shop/notice/topNoticeList',
method: 'GET',
data: {}
})
.then(({
data
}) => {
news.value = data
})
}
/**
* 加载商品标题分组列表
*/
const getTag = () => {
http.request({
url: '/prod/tag/prodTagList',
method: 'GET',
data: {}
})
.then(({
data
}) => {
taglist.value = data
for (let i = 0; i < data.length; i++) {
updata.value = false
updata.value = true
getTagProd(data[i].id, i)
}
})
}
const getTagProd = (id, index) => {
http.request({
url: '/prod/prodListByTagId',
method: 'GET',
data: {
tagId: id,
size: 6
}
})
.then(({
data
}) => {
updata.value = false
updata.value = true
const taglistParam = taglist.value
taglistParam[index].prods = data.records
taglist.value = taglistParam
})
}
</script>
<style scoped lang="scss">
@use './index.scss';
</style>

@ -5,12 +5,10 @@
}
image {
display: block;
width: 150rpx;
width: 180rpx;
height: 150rpx;
margin: auto;
border-radius: 50%;
width: 150rpx;
height: 150rpx;
// border-radius: 50%;
margin-bottom: 8%;
}
.login-form {

@ -1,375 +1,293 @@
<template>
<view class="container">
<!-- 用户信息 -->
<view
v-if="isAuthInfo"
class="userinfo"
>
<view class="userinfo-con">
<view class="userinfo-avatar">
<image
:src="
loginResult.pic
?
(loginResult.pic.indexOf('http') === -1 ? picDomain + loginResult.pic : loginResult.pic)
:
'/static/images/icon/head04.png'
"
/>
</view>
<view class="userinfo-name">
<view>{{ loginResult.nickName ? loginResult.nickName : "用户昵称" }}</view>
</view>
</view>
</view>
<view
v-if="!isAuthInfo"
class="userinfo-none"
>
<view
class="default-pic"
@tap="toLogin"
>
<image src="@/static/images/icon/head04.png" />
</view>
<view
class="none-login"
@tap="toLogin"
>
<button class="unlogin">
未登录
</button>
<button class="click-login">
点击登录账号
</button>
</view>
</view>
<!-- end 用户信息 -->
<view class="list-cont">
<!-- 订单状态 -->
<view class="total-order">
<view class="order-tit">
<text style="font-weight:bold">
我的订单
</text>
<view
class="checkmore"
data-sts="0"
@tap="toOrderListPage"
>
<text>查看全部</text>
<text class="arrowhead" />
</view>
</view>
<view class="procedure">
<view
class="items"
data-sts="1"
@tap="toOrderListPage"
>
<image src="@/static/images/icon/toPay.png" />
<text>待支付</text>
<text
v-if="orderAmount.unPay>0"
class="num-badge"
>
{{ orderAmount.unPay }}
</text>
</view>
<view
class="items"
data-sts="2"
@tap="toOrderListPage"
>
<image src="@/static/images/icon/toDelivery.png" />
<text>待发货</text>
<text
v-if="orderAmount.payed>0"
class="num-badge"
>
{{ orderAmount.payed }}
</text>
</view>
<view
class="items"
data-sts="3"
@tap="toOrderListPage"
>
<image src="@/static/images/icon/toTake.png" />
<text>待收货</text>
<text
v-if="orderAmount.consignment>0"
class="num-badge"
>
{{ orderAmount.consignment }}
</text>
</view>
<view
class="items"
data-sts="5"
@tap="toOrderListPage"
>
<image src="@/static/images/icon/toComment.png" />
<text>已完成</text>
</view>
</view>
</view>
<!--end 订单状态 -->
<view class="prod-col">
<view
class="col-item"
@tap="myCollectionHandle"
>
<view
v-if="loginResult"
class="num"
>
{{ collectionCount }}
</view>
<view
v-else
class="num"
>
--
</view>
<view class="tit">
我的收藏
</view>
</view>
<view
class="col-item"
@tap="handleTips"
>
<view
v-if="loginResult"
class="num"
>
5
</view>
<view
v-else
class="num"
>
--
</view>
<view class="tit">
我的消息
</view>
</view>
<view
class="col-item"
@tap="handleTips"
>
<view
v-if="loginResult"
class="num"
>
3
</view>
<view
v-else
class="num"
>
--
</view>
<view class="tit">
我的足迹
</view>
</view>
</view>
<view class="my-menu">
<view
class="memu-item"
@tap="toDistCenter"
>
<view class="i-name">
<image src="@/static/images/icon/promotion.png" />
<text>分销中心</text>
</view>
<view class="arrowhead" />
</view>
<view
class="memu-item"
@tap="toCouponCenter"
>
<view class="i-name">
<image src="@/static/images/icon/getCoupon.png" />
<text>领券中心</text>
</view>
<view class="arrowhead" />
</view>
<view
class="memu-item"
@tap="toMyCouponPage"
>
<view class="i-name">
<image src="@/static/images/icon/myCoupon.png" />
<text>我的优惠券</text>
</view>
<view class="arrowhead" />
</view>
<view
class="memu-item"
@tap="toAddressList"
>
<view class="i-name">
<image src="@/static/images/icon/myAddr.png" />
<text>收货地址</text>
</view>
<view class="arrowhead" />
</view>
</view>
<!--end 列表项 -->
<view
v-if="isAuthInfo"
class="log-out"
@tap="logout"
>
<view class="log-out-n">
<text>退出登录</text>
</view>
</view>
</view>
</view>
</template>
<script setup>
const picDomain = import.meta.env.VITE_APP_RESOURCES_URL
const isAuthInfo = ref(false)
const loginResult = ref('')
const orderAmount = ref('')
/**
* 生命周期函数--监听页面显示
*/
onShow(() => {
loginResult.value = uni.getStorageSync('loginResult')
isAuthInfo.value = !!loginResult.value
//
if (isAuthInfo.value) {
uni.showLoading()
http.request({
url: '/p/myOrder/orderCount',
method: 'GET',
data: {}
})
.then(({ data }) => {
uni.hideLoading()
orderAmount.value = data
})
showCollectionCount()
}
})
const toDistCenter = () => {
uni.showToast({
icon: 'none',
title: '该功能未开源'
})
}
const toCouponCenter = () => {
uni.showToast({
icon: 'none',
title: '该功能未开源'
})
}
const toMyCouponPage = () => {
uni.showToast({
icon: 'none',
title: '该功能未开源'
})
}
const handleTips = () => {
uni.showToast({
icon: 'none',
title: '该功能未开源'
})
}
const toAddressList = () => {
uni.navigateTo({
url: '/pages/delivery-address/delivery-address'
})
}
const toOrderListPage = (e) => {
const sts = e.currentTarget.dataset.sts
uni.navigateTo({
url: '/pages/orderList/orderList?sts=' + sts
})
}
const collectionCount = ref(0)
/**
* 查询所有的收藏量
*/
const showCollectionCount = () => {
uni.showLoading()
http.request({
url: '/p/user/collection/count',
method: 'GET',
data: {}
})
.then(({ data }) => {
uni.hideLoading()
collectionCount.value = data
})
}
/**
* 我的收藏跳转
*/
const myCollectionHandle = () => {
let url = '/pages/prod-classify/prod-classify?sts=5'
const id = 0
const title = '我的收藏商品'
if (id) {
url += '&tagid=' + id + '&title=' + title
}
uni.navigateTo({
url
})
}
/**
* 去登陆
*/
const toLogin = () => {
uni.navigateTo({
url: '/pages/accountLogin/accountLogin'
})
}
/**
* 退出登录
*/
const logout = () => {
http.request({
url: '/logOut',
method: 'post'
})
.then(() => {
util.removeTabBadge()
uni.removeStorageSync('loginResult')
uni.removeStorageSync('token')
uni.showToast({
title: '退出成功',
icon: 'none'
})
orderAmount.value = ''
setTimeout(() => {
uni.switchTab({
url: '/pages/index/index'
})
}, 1000)
})
}
</script>
<style scoped lang="scss">
@use './user.scss';
<template>
<view class="container">
<!-- 用户信息 -->
<view v-if="isAuthInfo" class="userinfo">
<view class="userinfo-con">
<view class="userinfo-avatar">
<image :src="
loginResult.pic
?
(loginResult.pic.indexOf('http') === -1 ? picDomain + loginResult.pic : loginResult.pic)
:
'/static/images/icon/head04.png'
" />
</view>
<view class="userinfo-name">
<view>{{ loginResult.nickName ? loginResult.nickName : "用户昵称" }}</view>
</view>
</view>
</view>
<view v-if="!isAuthInfo" class="userinfo-none">
<view class="default-pic" @tap="toLogin">
<image src="@/static/images/icon/head04.png" />
</view>
<view class="none-login" @tap="toLogin">
<button class="unlogin">
未登录
</button>
<button class="click-login">
点击登录账号
</button>
</view>
</view>
<!-- end 用户信息 -->
<view class="list-cont">
<!-- 订单状态 -->
<view class="total-order">
<view class="order-tit">
<text style="font-weight:bold">
我的订单
</text>
<view class="checkmore" data-sts="0" @tap="toOrderListPage">
<text>查看全部</text>
<text class="arrowhead" />
</view>
</view>
<view class="procedure">
<view class="items" data-sts="1" @tap="toOrderListPage">
<image src="@/static/images/icon/toPay.png" />
<text>待支付</text>
<text v-if="orderAmount.unPay>0" class="num-badge">
{{ orderAmount.unPay }}
</text>
</view>
<view class="items" data-sts="2" @tap="toOrderListPage">
<image src="@/static/images/icon/toDelivery.png" />
<text>待发货</text>
<text v-if="orderAmount.payed>0" class="num-badge">
{{ orderAmount.payed }}
</text>
</view>
<view class="items" data-sts="3" @tap="toOrderListPage">
<image src="@/static/images/icon/toTake.png" />
<text>待收货</text>
<text v-if="orderAmount.consignment>0" class="num-badge">
{{ orderAmount.consignment }}
</text>
</view>
<view class="items" data-sts="5" @tap="toOrderListPage">
<image src="@/static/images/icon/toComment.png" />
<text>已完成</text>
</view>
</view>
</view>
<!--end 订单状态 -->
<view class="prod-col">
<view class="col-item" @tap="myCollectionHandle">
<view v-if="loginResult" class="num">
{{ collectionCount }}
</view>
<view v-else class="num">
--
</view>
<view class="tit">
我的收藏
</view>
</view>
<view class="col-item" @tap="handleTips">
<view v-if="loginResult" class="num">
5
</view>
<view v-else class="num">
--
</view>
<view class="tit">
我的消息
</view>
</view>
<view class="col-item" @tap="handleTips">
<view v-if="loginResult" class="num">
3
</view>
<view v-else class="num">
--
</view>
<view class="tit">
我的足迹
</view>
</view>
</view>
<view class="my-menu">
<view class="memu-item" @tap="toDistCenter">
<view class="i-name">
<image src="@/static/images/icon/promotion.png" />
<text>分销中心</text>
</view>
<view class="arrowhead" />
</view>
<view class="memu-item" @tap="toCouponCenter">
<view class="i-name">
<image src="@/static/images/icon/getCoupon.png" />
<text>领券中心</text>
</view>
<view class="arrowhead" />
</view>
<view class="memu-item" @tap="toMyCouponPage">
<view class="i-name">
<image src="@/static/images/icon/myCoupon.png" />
<text>我的优惠券</text>
</view>
<view class="arrowhead" />
</view>
<view class="memu-item" @tap="toAddressList">
<view class="i-name">
<image src="@/static/images/icon/myAddr.png" />
<text>收货地址</text>
</view>
<view class="arrowhead" />
</view>
</view>
<!--end 列表项 -->
<view v-if="isAuthInfo" class="log-out" @tap="logout">
<view class="log-out-n">
<text>退出登录</text>
</view>
</view>
</view>
</view>
</template>
<script setup>
const picDomain = import.meta.env.VITE_APP_RESOURCES_URL
const isAuthInfo = ref(false)
const loginResult = ref('')
const orderAmount = ref('')
/**
* 生命周期函数--监听页面显示
*/
onShow(() => {
loginResult.value = uni.getStorageSync('loginResult')
isAuthInfo.value = !!loginResult.value
//
if (isAuthInfo.value) {
uni.showLoading()
http.request({
url: '/p/myOrder/orderCount',
method: 'GET',
data: {}
})
.then(({
data
}) => {
uni.hideLoading()
orderAmount.value = data
})
showCollectionCount()
}
})
const toDistCenter = () => {
uni.showToast({
icon: 'none',
title: '功能开发中'
})
}
const toCouponCenter = () => {
uni.showToast({
icon: 'none',
title: '功能开发中'
})
}
const toMyCouponPage = () => {
uni.showToast({
icon: 'none',
title: '功能开发中'
})
}
const handleTips = () => {
uni.showToast({
icon: 'none',
title: '功能开发中'
})
}
const toAddressList = () => {
uni.navigateTo({
url: '/pages/delivery-address/delivery-address'
})
}
const toOrderListPage = (e) => {
const sts = e.currentTarget.dataset.sts
uni.navigateTo({
url: '/pages/orderList/orderList?sts=' + sts
})
}
const collectionCount = ref(0)
/**
* 查询所有的收藏量
*/
const showCollectionCount = () => {
uni.showLoading()
http.request({
url: '/p/user/collection/count',
method: 'GET',
data: {}
})
.then(({
data
}) => {
uni.hideLoading()
collectionCount.value = data
})
}
/**
* 我的收藏跳转
*/
const myCollectionHandle = () => {
let url = '/pages/prod-classify/prod-classify?sts=5'
const id = 0
const title = '我的收藏商品'
if (id) {
url += '&tagid=' + id + '&title=' + title
}
uni.navigateTo({
url
})
}
/**
* 去登陆
*/
const toLogin = () => {
uni.navigateTo({
url: '/pages/accountLogin/accountLogin'
})
}
/**
* 退出登录
*/
const logout = () => {
http.request({
url: '/logOut',
method: 'post'
})
.then(() => {
util.removeTabBadge()
uni.removeStorageSync('loginResult')
uni.removeStorageSync('token')
uni.showToast({
title: '退出成功',
icon: 'none'
})
orderAmount.value = ''
setTimeout(() => {
uni.switchTab({
url: '/pages/index/index'
})
}, 1000)
})
}
</script>
<style scoped lang="scss">
@use './user.scss';
</style>

Binary file not shown.

Before

Width:  |  Height:  |  Size: 9.3 KiB

After

Width:  |  Height:  |  Size: 32 KiB

@ -78,9 +78,9 @@ const props = defineProps({
const toxFullscreen = ref(false)
let hasInit = false
let hasChange = false
let hasChange = -1
watch(() => props.modelValue, (val) => {
if (!hasChange && hasInit) {
if (hasChange < 1 && hasInit) {
setContent(val)
}
})
@ -151,7 +151,7 @@ const initTinymce = () => {
}
hasInit = true
editor.on('NodeChange Change KeyUp SetContent', () => {
hasChange = true
hasChange += 1
emit('update:modelValue', editor.getContent())
})
},

@ -15,14 +15,14 @@
v-if="!sidebarFold"
class="site-navbar-lg"
>
mall4j建站后台
甄味馆后台
</span>
<span
v-else
class="site-navbar-mini"
:style="fontCloseSize"
>
mall4j
甄味馆
</span>
</div>
<!--右侧数据-->

@ -1,6 +1,6 @@
<template>
<div class="mod-home">
<p>一个基于spring bootspring oauth2.0mybatisredis的轻量级前后端分离拥有完整sku和下单流程的完全开源商城</p>
<!-- <p>一个基于spring bootspring oauth2.0mybatisredis的轻量级前后端分离拥有完整sku和下单流程的完全开源商城</p>
<p>&nbsp;</p>
<p>该项目仅供学习参考可供个人学习使用如需商用联系作者进行授权否则必将追究法律责任</p>
<p>&nbsp;</p>
@ -123,7 +123,7 @@
<code>ApiApplication</code> 启动项目前端接口
</li>
</ul>
<p>&nbsp;</p>
<p>&nbsp;</p> -->
</div>
</template>

@ -432,7 +432,7 @@ const addOrUpdateRef = ref(null)
*/
const onAddOrUpdate = () => {
ElMessage({
message: '该功能未开源',
message: '功能开发中',
type: 'warning',
duration: 1500
})

Loading…
Cancel
Save