移动端个人中心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


相关文章
|
移动开发 人工智能 前端开发
7 款最棒的 React 移动端 UI 组件库 - 特别针对国内使用场景推荐
优秀的 React UI 移动端组件库和模版框架,帮我们节省开发时间,提高开发效率,统一设计语言。更棒的是内置的功能复杂,我们自己很难处理的常用组件,比如表格、表单、富文本编辑器、时间日期选择器、实时拖拽组件等,再进一步,还有帮我们把组件的轮子装好的 React admin 后台管理系统。本文推荐 7 款适用于中文使用者习惯的开源 React 移动端 UI 库,特别针对国内使用场景推荐。
4609 0
|
5天前
|
移动开发
【实用】一组原创原生样式的基础控件、UI组件样式(偏向移动端H5页面的样式)
【实用】一组原创原生样式的基础控件、UI组件样式(偏向移动端H5页面的样式)
【实用】一组原创原生样式的基础控件、UI组件样式(偏向移动端H5页面的样式)
|
5天前
|
前端开发
element-ui组件DatePicker日期选择器移动端兼容
element-ui组件DatePicker日期选择器移动端兼容
element-ui组件DatePicker日期选择器移动端兼容
|
5天前
在温系统下制作马克系统引导安装镜像启动U盘安装马克OS
在温系统下制作马克系统引导安装镜像启动U盘安装马克OS
在温系统下制作马克系统引导安装镜像启动U盘安装马克OS
|
6月前
|
JavaScript 前端开发 小程序
Vue移动端UI框架
Vue移动端UI框架
109 0
|
6月前
|
JavaScript
Vue移动端框架Mint UI教程-跳转新页面(四)
Vue移动端框架Mint UI教程-跳转新页面(四)
52 0
|
6月前
|
JSON JavaScript 前端开发
Vue移动端框架Mint UI教程-接口跨域问题(七)
Vue移动端框架Mint UI教程-接口跨域问题(七)
40 0
|
6月前
|
JSON JavaScript 数据格式
Vue移动端框架Mint UI教程-数据渲染到页面(六)
Vue移动端框架Mint UI教程-数据渲染到页面(六)
42 0
|
6月前
|
JavaScript
Vue移动端框架Mint UI教程-底部导航栏(二)
Vue移动端框架Mint UI教程-底部导航栏(二)
55 0
|
6月前
|
JSON JavaScript API
Vue移动端框架Mint UI教程-调用模拟json数据(五)
Vue移动端框架Mint UI教程-调用模拟json数据(五)
42 0

热门文章

最新文章