Uni-Uadmin 一款uniapp+uviewUI开发的中后台管理系统模板实例。
全新毛玻璃UI视觉uniapp后台管理系统。使用了uni-app+uView-ui+uni-ui 等技术开发架构,内置了表格/表单/图表/列表及富文本编辑器,支持动态路由权限控制,错误页处理。
data:image/s3,"s3://crabby-images/453ad/453adfc2e26f3095f6402c728b8ce26c01fd8310" alt="在这里插入图片描述"
功能特性
? 动态毛玻璃底部Dock菜单 ? 支持动态权限管理、错误页处理 ? 内置多图表组件、表格、表单、瀑布流列表及富文本编辑器 ? 支持编译h5+APP+小程序端
data:image/s3,"s3://crabby-images/a2dfd/a2dfd22526095549f2bd4680de14158720ef44ec" alt="在这里插入图片描述"
技术架构
- 编码器:HbuilderX3.3.5
- 框架技术:vue.js+uniapp+vuex+mockjs
- UI组件库:uView-ui+uni-ui
- 弹窗组件:ua-popup(基于uni-app跨端弹框组件)
- 表格组件:ua-table(基于uni-app封装的多功能表格)
- 自定义组件:uaDock全新的dock风格tabbar组件
- 图表组件:u-charts图表库 模拟数据:mock.js
data:image/s3,"s3://crabby-images/451d5/451d5c2575ad02cf72b12eaad4641a6a9262c593" alt="在这里插入图片描述"
项目结构目录
data:image/s3,"s3://crabby-images/878ad/878ade3b56f8276305b1eccfd813ce41e6cae8fc" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/558bb/558bbc1a5e3d15d44e4a9137573c3ef07aed708b" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/391c8/391c84020010a6d6eb24cb614bafee3a4b3db7b6" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/1a4fa/1a4fa7c3fb6bc2b6df74a2b307d8606a626beebe" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/faa12/faa12e8558200fb943839a176f23f3e75b61e2a2" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/47fd7/47fd7d61addab359d8c11f1271ad6c561f8c4557" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/f0416/f0416e97f835f6f3bb18d02e4f08e62a44aede2b" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/e3b32/e3b32d0cb5c88fd5de762d7be9b2b63c11ced7b7" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c3b4b/c3b4bf3a1bb15ccdc1b8e218b3205ea3d5542f81" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/94ea3/94ea3a48c295a6548beb3140348db15673aa45dd" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/5f5da/5f5da8d71234d35d6a2227d39853c8ee2452161e" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/155ba/155baa15cd71878ed293da70f3eb8425956c3855" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/f95cc/f95cca0114cb0fd20c089f4ec3e93805d48822a0" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/d7b6b/d7b6b0ad32678c3f76e6a3e84fca7d98a79bcb02" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/0c4bd/0c4bd293f0046cb0b4559f5358cca2b5216462ee" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/617d3/617d3adf8d9e367fd5507f63b4ad124d87e0740c" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/fab7c/fab7c261208a90e5d10385de78f4f3b6b2026a6d" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/a3d0e/a3d0e60cf73a0513164014c34e60e871717df890" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/70b3f/70b3f0829188c863f91bfa0fb66125de3d0c449e" alt="在这里插入图片描述"
main.js配置
import Vue from 'vue'
import App from './App'
import store from './store'
Vue.prototype.$store = store
import Plugins from './plugins'
Vue.use(Plugins)
Vue.config.productionTip = false
App.mpType = 'app'
const app = new Vue({
...App,
store,
})
app.$mount()
公共页面模板
<!-- 公共页面模板 -->
<template>
<view class="ua__pageview flexbox flex-col" :style="{'--SKIN': $store.state.skin, 'background': bgcolor, 'color': color}">
<slot name="header" />
<view class="ua__scrollview flex1">
<slot />
</view>
<!--
<slot name="footer" />
<!--
<ua-dock v-if="dock && dock != 'false'" @click="handleDockClick" />
<!--
<ua-popup ref="uapopup" />
<!--
<ua-popup v-model="isVisibleSkin" position="right">
<Skin />
</ua-popup>
</view>
</template>
uni-app实现dock菜单
项目中的底部菜单采用了毛玻璃背景模糊效果。替代了系统tabbar组件。可左右丝滑滚动,图标支持iconfont和图片,另外还支持badge圆点数字提示。选项支持切换tabbar页面,跳转新页面
data:image/s3,"s3://crabby-images/a8396/a83968fb315ad43a08640c4d67d3a02fb2b99baf" alt="在这里插入图片描述" 自定义dock菜单模板
<!--
<template>
<view class="ua__dockbar">
<scroll-view class="ua__dock-scroll ua__filter" :class="platform" scroll-x :style="{'background': bgcolor}">
<view class="ua__dock-wrap">
<!-- Tab菜单项 -->
<block v-for="(item, index) in menu" :key="index">
<view v-if="item.type == 'divider'" class="ua__dock-divider"></view>
<view v-else class="ua__dock-item" :class="currentTabIndex == index ? 'cur' : ''" @click="switchTab(index, item)">
<text v-if="item.icon" class="iconfont nvuefont" :class="item.icon">{{item.icon}}</text>
<image v-if="item.img" :src="item.img" class="iconimg" :style="{'font-size': item.iconSize}" />
<text v-if="item.badge" class="ua__badge ua__dock-badge">{{item.badge}}</text>
<text v-if="item.dot" class="ua__badge-dot ua__dock-badgeDot"></text>
</view>
</block>
</view>
</scroll-view>
</view>
</template>
组件支持的props自定义参数配置如下
props: {
current: { type: [Number, String], default: 0 },
bgcolor: { type: String, default: null },
menu: {
type: Array,
default: () => [
{
type: 'tab',
path: '/pages/index/index',
icon: `\ue619`,
color: '#2979ff',
title: '首页',
},
{
type: 'tab',
path: '/pages/component/index',
icon: 'icon-component',
color: '#17c956',
title: '组件',
badge: 5,
},
{
type: 'tab',
path: '/pages/permission/index',
icon: 'icon-auth',
color: '#f44336',
title: '权限管理',
},
{
type: 'tab',
path: '/pages/setting/index',
icon: 'icon-wo',
color: '#8d1cff',
title: '设置',
dot: true,
},
]
},
},
uni-app自定义表格table组件
由于项目中需要用到表格组件,无赖网上的uniapp表格组件过于简单及功能性不全。于是就自己全新开发了一款表格组件ua-table。 data:image/s3,"s3://crabby-images/4b441/4b441fdde2700f6f3e358c5d28487900a8258017" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/d5e5e/d5e5e7b7af957ee0e81fb2d8157a3e0b2cfa8a30" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/bddd4/bddd475f5a4ddec6fe4db57efdfcf12b505702f2" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/91a3e/91a3eb4c9b95b9ff3c87f24e09afe524379ac79e" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c1dbc/c1dbcedc7e1af2d4490c6a1ca53dd66affed4dfd" alt="在这里插入图片描述" ua-table 支持全选/单选,列宽/居中及可左右、上下滑动固定表头及列,支持点击行返回行数据,返回单选及多选行列数据,自定义slot插槽等功能。能满足多样化表格需求。 data:image/s3,"s3://crabby-images/ed9d8/ed9d8e91f80dddc94d91c240ee48ebaec6117e67" alt="在这里插入图片描述" 调用非常简便,只需如下引入即可。
<ua-table
:columns="columns"
headerBgColor="#eee"
:headerBold="true"
stripe
padding="5px 0"
:data="data.list"
height="450rpx"
>
</ua-table>
<script>
import Mock from 'mockjs'
export default {
data() {
return {
columns: [
{type: 'index', align: 'center', width: 100, fixed: true},
{prop: 'title', label: '标题', align: 'left', width: '350'},
{prop: 'num', label: '搜索量', align: 'center', width: 120},
],
data: Mock.mock({
total: 100,
page: 1,
pagesize: 10,
'list|10': [
{
id: '@id()',
title: '@ctitle(10, 20)',
num: '@integer(1000,10000)'
}
]
}),
}
}
}
</script>
如果想要自定义slot插槽,则可以通过如下方式使用。
<ua-table
:columns="columns"
headerBgColor="#eee"
:headerBold="true"
:stripe="true"
:data="data.list"
@row-click="handleRowClick"
@select="handleCheck"
height="750rpx"
style="border:1px solid #eee"
>
<template #default="{row, col, index}">
<block v-if="col.slot == 'image'">
<u-image :src="row.image" :lazy-load="true" height="100rpx" width="100rpx" @click="previewImage(row.image)" />
</block>
<block v-if="col.slot == 'switch'">
<u-switch v-model="row.switch" inactive-color="#fff" :size="36"></u-switch>
</block>
<block v-if="col.slot == 'tags'">
<u-tag :text="row.tags" bg-color="#607d8b" color="#fff" mode="dark" size="mini" />
</block>
<block v-if="col.slot == 'progress'">
<u-line-progress active-color="#1fb925" :percent="row.progress" :show-percent="false" :height="16"></u-line-progress>
</block>
<block v-if="col.slot == 'btns'">
<view class="ua__link success" @click.stop="handleFormEdit(row)">编辑</view>
<view class="ua__link error" @click.stop="handleDel(row, index)">删除</view>
</block>
</template>
</ua-table>
<script>
import Mock from 'mockjs'
export default {
data() {
return {
columns: [
{type: 'selection', align: 'center', width: 80, fixed: true},
{type: 'index', align: 'center', width: 80, fixed: true},
{prop: 'author', label: '作者', align: 'center', width: 120},
{prop: 'title', label: '标题', align: 'left', width: 350},
{slot: 'image', label: '图片', align: 'center', width: 120},
{slot: 'switch', label: '推荐', align: 'center', width: 100},
{slot: 'tags', label: '标签', align: 'center', width: 100},
{slot: 'progress', label: '热度', align: 'center', width: 150},
{prop: 'date', label: '发布时间', align: 'left', width: 300},
{slot: 'btns', label: '操作', align: 'center', width: 150, fixed: 'right'},
],
data: Mock.mock({
total: 100,
page: 1,
pagesize: 10,
'list|30': [
{
id: '@id()',
author: '@cname()',
title: '@ctitle(10, 20)',
image: 'https://picsum.photos/400/400?random=' + '@guid()',
switch: '@boolean()',
'tags|1': ['admin', 'test', 'dev'],
progress: '@integer(30, 90)',
date: '@datetime()'
}
]
}),
}
}
}
</script>
以上就是uniapp开发移动端后台管理系统,希望对大家有些帮助~ 最后附上两个项目实例
data:image/s3,"s3://crabby-images/1f507/1f50753ecae5106787f6356c1f7322057cd7ae08" alt="在这里插入图片描述"
|