移动端个人中心UI设计

news2025/1/16 7:55:12

效果图

源码如下

页面设计

<template>
  <div class="container">
    <!--  顶部用户信息 start-->
    <div class="header">
      <div class="user-info">
        <van-image class="user-img" round width="70" :src="userInfo.userImg"></van-image>
        <div class="user-desc">
          <span class="user-nickname">{{ userInfo.nickname }}</span>
          <span class="user-username">账号名:{{ userInfo.username }}</span>
        </div>
        <van-icon @click="onSet" class="user-set" size="large" name="setting-o"/>
      </div>
    </div>
    <!--  顶部用户信息 end-->
    <!--  我的订单 start-->
    <div class="order">
      <span>我的订单</span>
      <van-button class="order-button" @click="onOrdersList" color="#ff5402" round size="mini">全部</van-button>
      <van-grid class="order-grid" :border="false" column-num="5">
        <van-grid-item v-for="(item,index) in orderGrids" :key="index" :icon="item.icon" :text="item.text"
                       :to="item.to"></van-grid-item>
      </van-grid>
    </div>
    <!--  我的订单 end-->
  </div>
</template>

逻辑编写

<script setup>
import {onMounted, reactive, ref} from "vue";
import axios from "../../utils/request";
import {useDataStore} from "../../stores/dataStore"
import {useRouter} from 'vue-router'

const router = useRouter()
const dataStore = useDataStore()
//用户信息
const userInfo = ref(0)
//订单宫格数据
const orderGrids = reactive([
  {
    icon: "",
    text: '待付款',
    to: '',
  },
  {
    icon: "",
    text: '待发货',
    to: '',
  },
  {
    icon: "",
    text: '待收货',
    to: '',
  },
  {
    icon: "",
    text: '待评价',
    to: '',
  },
  {
    icon: "",
    text: '售后',
    to: '',
  },
])
onMounted(() => {
  axios.get("front/user/findById", {
    params: {
      userId: dataStore.userId
    }
  }).then(res => {
    if (res.data.code == 200) {
      userInfo.value = res.data.data
    }
  })
})
/**
 * 用户设置按钮
 */
const onSet = () => {
  router.push("/user/setting")
}
/**
 * 用户全部订单
 */
const onOrdersList = () => {
  router.push("/user/orders")
}
</script>

样式设计

<style scoped>
.header {
  background-image: linear-gradient(135deg, #fdf0e7 10%, #fce3ba 100%) !important;;
  height: 110px;
  border-radius: 0 0 15px 15px;
}

/**
个人信息模块
 */
.user-info {
  display: flex;
}

.user-img {
  margin: 10px;
}

.user-nickname {
  display: block;
  font-weight: bolder;
  font-size: 18px;
  margin-top: 20px;
  margin-left: 10px;
  color: #170f07;
}

.user-username {
  display: block;
  margin-left: 10px;
  margin-top: 5px;
  color: #70635a;
}

.user-set {
  margin-left: 160px;
  margin-top: 20px;
}

/**
订单模块
 */
.order {
  border-radius: 15px;
  margin: 6px;
  background-color: #ffffff;
  padding: 10px;
}

.order span {
  font-size: 16px;
  font-weight: bolder;
  color: #170f07;
}

.order-button {
  float: right;
}
</style>

全部代码

<template>
  <div class="container">
    <!--  顶部用户信息 start-->
    <div class="header">
      <div class="user-info">
        <van-image class="user-img" round width="70" :src="userInfo.userImg"></van-image>
        <div class="user-desc">
          <span class="user-nickname">{{ userInfo.nickname }}</span>
          <span class="user-username">账号名:{{ userInfo.username }}</span>
        </div>
        <van-icon @click="onSet" class="user-set" size="large" name="setting-o"/>
      </div>
    </div>
    <!--  顶部用户信息 end-->
    <!--  我的订单 start-->
    <div class="order">
      <span>我的订单</span>
      <van-button class="order-button" @click="onOrdersList" color="#ff5402" round size="mini">全部</van-button>
      <van-grid class="order-grid" :border="false" column-num="5">
        <van-grid-item v-for="(item,index) in orderGrids" :key="index" :icon="item.icon" :text="item.text"
                       :to="item.to"></van-grid-item>
      </van-grid>
    </div>
    <!--  我的订单 end-->
  </div>
</template>

<script setup>
import {onMounted, reactive, ref} from "vue";
import axios from "../../utils/request";
import {useDataStore} from "../../stores/dataStore"
import {useRouter} from 'vue-router'

const router = useRouter()
const dataStore = useDataStore()
//用户信息
const userInfo = ref(0)
//订单宫格数据
const orderGrids = reactive([
  {
    icon: "",
    text: '待付款',
    to: '',
  },
  {
    icon: "",
    text: '待发货',
    to: '',
  },
  {
    icon: "",
    text: '待收货',
    to: '',
  },
  {
    icon: "",
    text: '待评价',
    to: '',
  },
  {
    icon: "",
    text: '售后',
    to: '',
  },
])
onMounted(() => {
  axios.get("front/user/findById", {
    params: {
      userId: dataStore.userId
    }
  }).then(res => {
    if (res.data.code == 200) {
      userInfo.value = res.data.data
    }
  })
})
/**
 * 用户设置按钮
 */
const onSet = () => {
  router.push("/user/setting")
}
/**
 * 用户全部订单
 */
const onOrdersList = () => {
  router.push("/user/orders")
}
</script>

<style scoped>
.header {
  background-image: linear-gradient(135deg, #fdf0e7 10%, #fce3ba 100%) !important;;
  height: 110px;
  border-radius: 0 0 15px 15px;
}

/**
个人信息模块
 */
.user-info {
  display: flex;
}

.user-img {
  margin: 10px;
}

.user-nickname {
  display: block;
  font-weight: bolder;
  font-size: 18px;
  margin-top: 20px;
  margin-left: 10px;
  color: #170f07;
}

.user-username {
  display: block;
  margin-left: 10px;
  margin-top: 5px;
  color: #70635a;
}

.user-set {
  margin-left: 160px;
  margin-top: 20px;
}

/**
订单模块
 */
.order {
  border-radius: 15px;
  margin: 6px;
  background-color: #ffffff;
  padding: 10px;
}

.order span {
  font-size: 16px;
  font-weight: bolder;
  color: #170f07;
}

.order-button {
  float: right;
}
</style>

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【打造超酷的GitHub主页】

文章目录 Github状态信息-api账户信息统计最常用语言Repo卡片 社交统计统计访问次数徽标 首先上地址&#xff1a;https://gitee.com/java_wxid/giteeprofile/blob/master/README.md 为了照顾一部分网络较差的的朋友们&#xff0c;这里使用国内的gitee仓库将主页代码提供给大家&…

C语言 位运算符 “|“ 的5种高级用法

前言 在上一篇文章中&#xff0c;我们介绍了&运算符的高级用法&#xff0c;本篇文章&#xff0c;我们将介绍| 运算符的一些高级用法。 一、人物简介 第一位闪亮登场&#xff0c;有请今后会一直教我们C语言的老师 —— 自在。 第二位上场的是和我们一起学习的小白程序猿 —…

16、博客列表加载效果 - 博客界面改造文章(202307)

最近闲来无事&#xff0c;就想着把博客界面弄得再有点动画效果&#xff0c;于是就找了延迟函数&#xff0c;把博客的内容列表加载的动画写出来了。 该动画效果还是挺炫的&#xff0c;但是因为刷新页面&#xff0c;下面列表的显示需要拉动到底下才看到&#xff0c;所以这里只能记…

微信小程序监测版本更新

在index.js里面 不放到app.js里面是因为有登录页面&#xff0c;在登录页面显示更新不太友好 onShow() {const updateManager wx.getUpdateManager()// 请求完新版本信息的回调updateManager.onCheckForUpdate(res > {if (res.hasUpdate) {// 新版本下载成功updateManage…

【腾讯云 Cloud Studio 实战训练营】体验搭建软件系统,无经验也能做开发

文章目录 前言IDE 解放开发者的生产力功能强大的 IDE快速搭建 Vue 开发环境注册 Cloud Studio进入Vue预置开发环境安装相关依赖包主文件 main.js 引入相关库和包首页增加移动端默认样式增加主要代码 IDE 的适用场景总结 前言 云计算技术的不断发展为代码开发带来了全新的体验&…

【Uniapp】支付链转二维码

前言 提示&#xff1a;这个是一个很小的项目&#xff0c;大概30分钟就能搞定 实现方式&#xff1a;输入支付代码&#xff0c;存储到对应的数据库表中&#xff0c;二维码访问一个PHP文件通过id来进行重定向&#xff0c;这样就可以使每张二维码都是固定的&#xff0c;替换二维码…

CS5213 国产HDMI转VGA带音频方案芯片|CS5213规格书|CS5213原理图

集睿致远/ASL推出的CS5213芯片是一个国产HDMI&#xff08;高清多媒体接口&#xff09;到VGA桥接芯片。它将HDMI信号转换为标准VGA信号它可以在适配器、智能电缆等设备中设计 CS5213特征 将HDMI信号转换为VGA输出 支持数字信号到模似信号的转换 支持 HDCP 1.0/1.1/1.2 操作简…

OpenAI API访问速度不佳?试试用Vercel来加速!

前言 众所周知&#xff0c;使用openAI API在国内访问体验并不佳&#xff0c;经常遇到访问较慢或者访问失败的问题。本文着重讲讲怎么解决这个问题&#xff0c;让我们日常开发和使用能够更方便的体验到AI带来的便利 为了帮大家省钱&#xff0c;也为了方便操作&#xff0c;实现…

论文解读|进一步融合:体积融合中6D姿态估计的多对象推理

原创 | 文 BFT机器人 01 背景 机器人等智能设备需要从它们的车载视觉系统中获得高效的基于物体的场景表示&#xff0c;以解释接触、物理和遮挡。已识别的精确对象模型将与未识别结构的非参数重建一起发挥重要作用。 本文提出了一个系统用于估计实时的接触和遮挡的精确姿态。从…

手写openFeign

目录 背景步骤应用级别&#xff1a;1、建立被调用方2、建立调用方引入依赖 3、实现效果 原理级别&#xff1a;调动方代码&#xff08;注意impl在启动的时候里边是空的&#xff09;引入jar包的代码&#xff08;写好以后推到nexus上&#xff0c;再拉到上述调用方服务中&#xff0…

收集用户隐私行为规范与修改指引

为更好地保护用户隐私信息&#xff0c;优化用户体验&#xff0c;平台对小程序内的收集用户隐私行为进行规范&#xff0c;开发者可自查所涉及的违规内容&#xff0c;并参照修改指引进行相应整改。 常见违规内容 一、隐私政策协议默示同意 小程序在收集用户数据前&#xff0c;…

【高级程序设计语言C++】二叉搜索树

1. 二叉搜索树的概念2. 二叉搜索树的功能2.1. 二叉搜索树的简单模型2.2. 二叉搜索树的查找2.3. 二叉搜索树的插入2.4. 二叉搜索树的删除 3. 二叉搜索树的性能分析 1. 二叉搜索树的概念 二叉搜索树&#xff08;Binary Search Tree&#xff0c;简称BST&#xff09;是一种常见的二…

【C/C++】类之间的纵向关系——继承的概念

创作不易&#xff0c;本篇文章如果帮助到了你&#xff0c;还请点赞 关注支持一下♡>&#x16966;<)!! 主页专栏有更多知识&#xff0c;如有疑问欢迎大家指正讨论&#xff0c;共同进步&#xff01; &#x1f525;c系列专栏&#xff1a;C/C零基础到精通 &#x1f525; 给大…

C++——继承(2)详解

目录 一.子类和父类对象的赋值转换 子类对象赋值父类对象的另外两种方式&#xff1a; 总结&#xff1a; 二.父类与子类的作用域 1. 在继承体系中基类和派生类都有独立的作用域。 例&#xff1a; 2.作用域练习 练习1&#xff1a; 解决方法: 一.子类和父类对象的赋值转换 …

深入理解Java类加载机制中的双亲委派模型--根据源码探讨

前言&#xff1a; 今天和大家探讨一道Java中经典的面试题&#xff0c;这道面试题经常出现在各个公司的面试中&#xff0c;本篇文章主要讲解ava类加载机制中的双亲委派模型的知识。该专栏比较适合刚入坑Java的小白以及准备秋招的大佬阅读。 如果文章有什么需要改进的地方欢迎大…

Cesium态势标绘专题-三角旗标、矩形旗标、曲线旗标(标绘+编辑)

标绘专题介绍:态势标绘专题介绍_总要学点什么的博客-CSDN博客 入口文件:Cesium态势标绘专题-入口_总要学点什么的博客-CSDN博客 辅助文件:Cesium态势标绘专题-辅助文件_总要学点什么的博客-CSDN博客 本专题没有废话,只有代码,代码中涉及到的引入文件方法,从上面三个链…

前端JavaScript作用域详解

目录 前言 什么是作用域 作用域类型 全局作用域 局部作用域 块级作用域 ES6之前 ES6以后 作用域链 变量提升 基础概念 优先级问题 闭包 定义 特点 使用场景 封装私有变量 延长变量周期 模块化、命名空间 缓存 ES6的作用域 const、let 块级作用域 变量提…

tinymce4/5实现将word中内容(文字图片等)直接粘贴至编辑器中——利用插件tinymce-powerpaste-plugin

TinyMCE是一款易用、且功能强大的所见即所得的富文本编辑器。同类程序有&#xff1a;UEditor、Kindeditor、Simditor、CKEditor、wangEditor、Suneditor、froala等等。 TinyMCE的优势&#xff1a; 开源可商用&#xff0c;基于LGPL2.1 插件丰富&#xff0c;自带插件基本涵盖日常…

关于时序图

时序图 01 什么是时序图&#xff1f;02 时序图的组成元素2.1 对象2.2 生命线2.3 消息 03 如何绘制 01 什么是时序图&#xff1f; 时序图是UML交互图中的一类&#xff0c;又名序列图、顺序图。 用于描述对象之间的传递消息的时间顺序&#xff08;包括发送消息、接收消息、处理…

一个女程序员的成长之路

2013年大学毕业了&#xff0c;带着迷茫与好玩&#xff0c;我还年轻的心态&#xff0c;开始在郑州寻觅工作机会&#xff0c;最后很荣幸的在一家小公司入职了&#xff0c;工作的内容是给种植大棚的用户打电话&#xff0c;推销农药。每天就是在网上各种农业平台上面找号码&#xf…