【全栈】SprintBoot+vue3迷你商城(9)

server/2025/2/2 15:20:50/

【全栈】SprintBoot+vue3迷你商城(9)

往期的文章都在这里啦,大家有兴趣可以看一下

后端部分:

【全栈】SprintBoot+vue3迷你商城(1)
【全栈】SprintBoot+vue3迷你商城(2)
【全栈】SprintBoot+vue3迷你商城-扩展:利用python爬虫爬取商品数据
【全栈】SprintBoot+vue3迷你商城(3)
【全栈】SprintBoot+vue3迷你商城(4)
【全栈】SprintBoot+vue3迷你商城(5)
【全栈】SprintBoot+vue3迷你商城(6)

前端部分:

【全栈】SprintBoot+vue3迷你商城-扩展:vue的基本用法

【全栈】SprintBoot+vue3迷你商城-扩展:vue3项目创建及目录介绍

【全栈】SprintBoot+vue3迷你商城(7)

【全栈】SprintBoot+vue3迷你商城(8)

本期我们来写用户基本信息显示以及购物车显示的页面

文章目录

  • 【全栈】SprintBoot+vue3迷你商城(9)
    • 1.用户基本信息显示页面的开发
      • 1.1.搭建页面,绑定数据与函数
      • 1.2.制定与后端接口交互的函数
      • 1.3.效果展示
    • 2.购物车显示的页面开发
      • 2.1.搭建页面,绑定数据与函数
      • 2.2.制定与后端接口交互的函数
      • 2.3.效果展示
    • 3.总结

1.用户基本信息显示页面的开发

1.1.搭建页面,绑定数据与函数

/src/views/user/UserInfo.vue

<script lang="ts" setup>
import { ref } from 'vue'
import { ElMessage } from 'element-plus'
import { Plus } from '@element-plus/icons-vue'import type { UploadProps } from 'element-plus'import { useUserInfoStore } from '@/stores/userInfo';
const userInfoStore = useUserInfoStore();
const userInfoModel= ref(userInfoStore.info)const imageUrl = ref('')const handleAvatarSuccess: UploadProps['onSuccess'] = (response,uploadFile
) => {imageUrl.value = URL.createObjectURL(uploadFile.raw!)
}const beforeAvatarUpload: UploadProps['beforeUpload'] = (rawFile) => {if (rawFile.type !== 'image/jpeg') {ElMessage.error('Avatar picture must be JPG format!')return false} else if (rawFile.size / 1024 / 1024 > 2) {ElMessage.error('Avatar picture size can not exceed 2MB!')return false}return true
}const activeIndex = ref('1')
const handleSelect = (key: string, keyPath: string[]) => {console.log(key, keyPath)
}import { useRouter } from 'vue-router'; 
const router=useRouter();import { Avatar,  SwitchButton } from '@element-plus/icons-vue';import { useTokenStore } from '@/stores/token'; 
const tokenStore=useTokenStore();
const showLogoutDialog = ref(false);
const logout = () => {ElMessage.success('成功退出登录');tokenStore.removeToken();router.push('/login'); showLogoutDialog.value = false; 
};const handleClose = (done) => {ElMessage({message: '对话框已关闭',type: 'warning'});done();
};</script><template><div class="common-layout"><el-container class="bg"><el-header><el-menu :default-active="activeIndex" class="el-menu-demo" mode="horizontal" :ellipsis="false"@select="handleSelect"><el-menu-item index="0" @click="router.push('/')"><el-icon><ShoppingTrolley /></el-icon><img style="width: 100px" src="@/assets/logo2.jpg" alt="logo" /></el-menu-item><span style="font-size: medium;"><el-avatar style="margin-top:5px" :src="userInfoModel.userPic"  />{{ userInfoModel.userType }}:{{ userInfoModel.username }}</span><el-menu-item index="1" @click="router.push('/user/info')"><el-icon><Avatar /></el-icon>我的</el-menu-item><el-sub-menu index="2"><template #title>工具栏</template><el-menu-item v-if="userInfoModel.userType==='商家'" index="2-1" @click="router.push('/user/goods')">我的商品</el-menu-item><el-menu-item index="2-2" @click="router.push('/user/cart')">购物车</el-menu-item><el-menu-item index="2-3" @click="showLogoutDialog = true;"><el-icon><SwitchButton /></el-icon>退出登录</el-menu-item></el-sub-menu></el-menu><el-dialog title="确认退出登录" v-model="showLogoutDialog" width="30%" :before-close="handleClose"><span>确定要退出登录吗?</span><template #footer><span class="dialog-footer"><el-button @click="showLogoutDialog = false">取消</el-button><el-button type="primary" @click="logout">确定</el-button></span></template></el-dialog> </el-header><el-main><el-card class="page-container" style="background-color: coral;"><template #header><div class="header"><span>基本资料</span></div></template><p>用户头像:</p><el-upload class="avatar-uploader" action="https://run.mocky.io/v3/9d059bf9-4660-45f2-925d-ce80ad6c4d15":show-file-list="false" :on-success="handleAvatarSuccess" :before-upload="beforeAvatarUpload"><img v-if="userInfoModel.userPic" :src="userInfoModel.userPic" class="avatar" /><el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon></el-upload><el-row><el-col :span="12"><el-form label-width="100px" size="large"><el-form-item label="用户名"><el-input disabled :value="userInfoModel.username"></el-input></el-form-item><el-form-item label="用户类型"><el-input :value="userInfoModel.userType"></el-input></el-form-item><el-form-item label="用户手机号"><el-input :value="userInfoModel.phoneNumber"></el-input></el-form-item><el-form-item><el-button type="primary">提交修改</el-button></el-form-item></el-form></el-col></el-row></el-card></el-main></el-container></div><hr><div style="width: 300px;height: 200px;margin-left: auto;margin-right: auto;"><div style="margin-top: 100px;"><p style="text-align: center;margin-top: 10px;filter: opacity(50%);font-size: small;">迷你商城,本网站为练习网站。本站商品全在淘宝:"https://www.taobao.com"中获取,若对站内商品感兴趣,请到淘宝搜索相关商品并购买</p></div></div>
</template><style>
.avatar-uploader .avatar {width: 178px;height: 178px;display: block;
}
</style><style>
.avatar-uploader .el-upload {margin-bottom: 100px;margin-left: 200px;border: 1px dashed var(--el-border-color);border-radius: 6px;cursor: pointer;position: relative;overflow: hidden;transition: var(--el-transition-duration-fast);
}.avatar-uploader .el-upload:hover {border-color: var(--el-color-primary);
}.el-icon.avatar-uploader-icon {font-size: 28px;color: #8c939d;width: 178px;height: 178px;text-align: center;
}.el-menu--horizontal>.el-menu-item:nth-child(1) {margin-right: auto;
}.bg {background-color: pink;
}.el-menu-demo {background-color: coral;
}
</style>

1.2.制定与后端接口交互的函数

/src/api/user.js

javascript">export const userInfoService=()=>{return request.get('/user/userInfo');
}

1.3.效果展示

在这里插入图片描述

2.购物车显示的页面开发

2.1.搭建页面,绑定数据与函数

/src/views/user/UserCart.vue

<script lang="ts" setup>
import { ref } from 'vue'
import { useRouter } from 'vue-router';
const router=useRouter();
const activeIndex = ref('2-2')
const handleSelect = (key: string, keyPath: string[]) => {console.log(key, keyPath)
}
import { useUserInfoStore } from '@/stores/userInfo';
const userInfoStore = useUserInfoStore();
const userInfoModel= ref(userInfoStore.info)
import {userCartService} from '@/api/user'
const userCartList=ref([])
const userCart=async()=>{let result = await userCartService();userCartList.value=result.data;}
userCart();import { ElMessage } from 'element-plus';
import { Avatar,  SwitchButton } from '@element-plus/icons-vue';import { useTokenStore } from '@/stores/token'; 
const tokenStore=useTokenStore();
const showLogoutDialog = ref(false);
const logout = () => {ElMessage.success('成功退出登录');tokenStore.removeToken();router.push('/login'); showLogoutDialog.value = false; 
};const handleClose = (done) => {ElMessage({message: '对话框已关闭',type: 'warning'});done();
};
</script><template><div class="common-layout"><el-container class="bg"><el-header><el-menu :default-active="activeIndex" class="el-menu-demo" mode="horizontal" :ellipsis="false"@select="handleSelect"><el-menu-item index="0" @click="router.push('/')"><el-icon><ShoppingTrolley /></el-icon><img style="width: 100px" src="@/assets/logo2.jpg" alt="logo" /></el-menu-item><span style="font-size: medium;"><el-avatar style="margin-top:5px" :src="userInfoModel.userPic"  />{{ userInfoModel.userType }}:{{ userInfoModel.username }}</span><el-menu-item index="1" @click="router.push('/user/info')"><el-icon><Avatar /></el-icon>我的</el-menu-item><el-sub-menu index="2"><template #title>工具栏</template><el-menu-item v-if="userInfoModel.userType==='商家'" index="2-1" @click="router.push('/user/goods')">我的商品</el-menu-item><el-menu-item index="2-2" @click="router.push('/user/cart')">购物车</el-menu-item><el-menu-item index="2-3" @click="showLogoutDialog = true;"><el-icon><SwitchButton /></el-icon>退出登录</el-menu-item></el-sub-menu></el-menu><el-dialog title="确认退出登录" v-model="showLogoutDialog" width="30%" :before-close="handleClose"><span>确定要退出登录吗?</span><template #footer><span class="dialog-footer"><el-button @click="showLogoutDialog = false">取消</el-button><el-button type="primary" @click="logout">确定</el-button></span></template></el-dialog></el-header><el-main><div style="font-size: 50px;"><el-icon><ShoppingTrolley /></el-icon>购物车</div><el-descriptions direction="vertical" border style="margin-top: 20px" v-for="userCartModel in userCartList"><el-descriptions-item :rowspan="2" :width="140" label="商品图片" align="center"><el-image style="width: 100px; height: 100px":src="userCartModel.goodsImgUrl" /></el-descriptions-item><el-descriptions-item label="商品名/价格">{{ userCartModel.goodsName }}<span style="font-size: large;margin-left: 100px;">{{userCartModel.goodsPrice}}¥</span></el-descriptions-item><el-descriptions-item label="商家">{{ userCartModel.merchantName }}</el-descriptions-item></el-descriptions></el-main></el-container></div><hr><div style="width: 300px;height: 200px;margin-left: auto;margin-right: auto;"><div style="margin-top: 100px;"><p style="text-align: center;margin-top: 10px;filter: opacity(50%);font-size: small;">迷你商城,本网站为练习网站。本站商品全在淘宝:"https://www.taobao.com"中获取,若对站内商品感兴趣,请到淘宝搜索相关商品并购买</p></div></div>
</template><style>
.el-menu--horizontal>.el-menu-item:nth-child(1) {margin-right: auto;
}.bg {background-color: pink;
}.el-menu-demo {background-color: coral;
}
</style>

2.2.制定与后端接口交互的函数

/src/api/user.js

javascript">export const userCartService=()=>{return request.get('/user/cart');
}

2.3.效果展示

在这里插入图片描述

3.总结

本期我们进行了用户基本信息显示与购物车显示的页面的开发,下期我们将搭建其余基本的页面。


http://www.ppmy.cn/server/164362.html

相关文章

第26节课:内容安全策略(CSP)—构建安全网页的防御盾

目录 CSP基础CSP的作用CSP的主要属性 配置CSP通过响应头配置CSP通过HTML <meta>标签配置CSP属性设置详解指定多个来源 配置示例说明 常见错误配置实践&#xff1a;CSP与XSS防护示例1&#xff1a;防止内联脚本和样式说明示例2&#xff1a;限制图片来源说明 限制与注意事项…

vscode和pycharm的区别

VSCode&#xff08;Visual Studio Code&#xff09;和 PyCharm 是两款常用的 Python 开发工具&#xff0c;它们在功能和使用体验上有一些关键区别&#xff1a; 1. 核心定位 VSCode&#xff1a;轻量级、多语言支持的代码编辑器&#xff0c;依靠插件扩展 Python 开发能力。PyCh…

GPT 本地运行输出界面简洁美观(命令行、界面、网页)

目录 展示图 代码配合命令行 界面运行 网页运行 展示图 命令行运行 tkinter界面运行 网页运行 代码配合命令行 import os import time from transformers import AutoModelForCausalLM, AutoTokenizer, TextStreamerstart_time time.time()model_path os.path.join(os.…

qt之数据库的使用二

本章主要介绍qt的数据库的查询功能。 在上一篇qt之数据库的文章基础上增加了数据库的查询功能&#xff0c;软件界面上增加了首记录&#xff0c;前一条&#xff0c;后一条&#xff0c;尾记录按钮。软件界面如下 部分程序如下 MainWindow.h如下 private:QSqlDatabase DB;//数据…

大数据挖掘--两个角度理解相似度计算理论

文章目录 0 相似度计算可以转换成什么问题1 集合相似度的应用1.1 集合相似度1.1文档相似度1.2 协同过滤用户-用户协同过滤物品-物品协同过滤 1.2 文档的shingling--将文档表示成集合1.2.1 k-shingling1.2.2 基于停用词的 shingling 1.3 最小哈希签名1.4 局部敏感哈希算法&#…

如何在Windows、Linux和macOS上安装Rust并完成Hello World

如何在Windows、Linux和macOS上安装Rust并完成Hello World 如果你刚刚开始学习Rust&#xff0c;第一步就是安装Rust并运行你的第一个程序&#xff01;本文将详细介绍如何在Windows、Linux和macOS上安装Rust&#xff0c;并编写一个简单的“Hello, World!”程序。 1. 安装Rust …

Signature

Signature 题目是&#xff1a; import ecdsaimport random​def ecdsa_test(dA,k):​sk ecdsa.SigningKey.from_secret_exponent(secexpdA,curveecdsa.SECP256k1)sig1 sk.sign(databHi., kk).hex()sig2 sk.sign(databhello., kk).hex()#不同的kr1 int(sig1[:64], 16)s1 i…

JavaEE:多线程编程中的同步与并发控制

JavaEE&#xff1a;多线程进阶2 一、Callable 接口1. 基本定义和接口签名2. Callable 接口的特点2.1 返回值2.2 异常处理2.3 灵活性 3. Callable 接口的劣势4. Callable 接口的使用场景4.1 需要返回结果的任务4.2 可能抛出异常的任务4.3 需要组合多个任务的结果 5. 总结 二、Re…