移动端个人中心UI设计

简介: 移动端个人中心UI设计

 效果图

image.gif编辑

源码如下

页面设计

<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>

image.gif

逻辑编写

<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>

image.gif

样式设计

<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>

image.gif

全部代码

<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>

image.gif


相关文章
|
22天前
|
Java 测试技术 持续交付
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
本文重点讲解如何搭建App自动化测试框架的思路,而非完整源码。主要内容包括实现目的、框架设计、环境依赖和框架的主要组成部分。适用于初学者,旨在帮助其快速掌握App自动化测试的基本技能。文中详细介绍了从需求分析到技术栈选择,再到具体模块的封装与实现,包括登录、截图、日志、测试报告和邮件服务等。同时提供了运行效果的展示,便于理解和实践。
64 4
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
|
5月前
|
编解码 Android开发 iOS开发
|
7月前
|
移动开发
【实用】一组原创原生样式的基础控件、UI组件样式(偏向移动端H5页面的样式)
【实用】一组原创原生样式的基础控件、UI组件样式(偏向移动端H5页面的样式)
【实用】一组原创原生样式的基础控件、UI组件样式(偏向移动端H5页面的样式)
|
7月前
【实用】一个移动端简单的UI弹窗组件,虽算不上高大上,但至少耐看
【实用】一个移动端简单的UI弹窗组件,虽算不上高大上,但至少耐看
|
7月前
|
前端开发
element-ui组件DatePicker日期选择器移动端兼容
element-ui组件DatePicker日期选择器移动端兼容
element-ui组件DatePicker日期选择器移动端兼容
|
7月前
|
JSON 小程序 前端开发
小程序使用npm以及常用的移动端UI插件
小程序使用npm以及常用的移动端UI插件
50 0
|
7月前
在温系统下制作马克系统引导安装镜像启动U盘安装马克OS
在温系统下制作马克系统引导安装镜像启动U盘安装马克OS
在温系统下制作马克系统引导安装镜像启动U盘安装马克OS
|
JavaScript 前端开发 小程序
Vue移动端UI框架
Vue移动端UI框架
201 0
|
JavaScript
Vue移动端框架Mint UI教程-跳转新页面(四)
Vue移动端框架Mint UI教程-跳转新页面(四)
131 0
|
JSON JavaScript 前端开发
Vue移动端框架Mint UI教程-接口跨域问题(七)
Vue移动端框架Mint UI教程-接口跨域问题(七)
70 0