'admin-21.03.04:新增fontawesome字体图标,其它页面细节优化等'

This commit is contained in:
lyt 2021-03-04 18:18:26 +08:00
parent ef54e25d6a
commit f3643271a7
7 changed files with 141 additions and 12 deletions

View File

@ -440,6 +440,21 @@ export const dynamicRoutes = [
icon: 'el-icon-platform-eleme' icon: 'el-icon-platform-eleme'
} }
}, },
{
path: '/pages/awesome',
name: 'awesome',
component: () => import('/@/views/pages/awesome/index.vue'),
meta: {
title: 'awesome 字体图标',
isLink: '',
isHide: false,
isKeepAlive: true,
isAffix: false,
isIframe: false,
auth: ['admin', 'test'],
icon: 'el-icon-set-up'
}
},
] ]
}, },
{ {

View File

@ -1,5 +1,8 @@
// 字体图标 url // 字体图标 url
const cssCdnUrlList: Array<string> = ['//at.alicdn.com/t/font_2298093_xviws8fx96h.css'] const cssCdnUrlList: Array<string> = [
'//at.alicdn.com/t/font_2298093_xviws8fx96h.css',
'//netdna.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css'
]
// 第三方 js url // 第三方 js url
const jsCdnUrlList: Array<string> = [] const jsCdnUrlList: Array<string> = []

View File

@ -6,14 +6,17 @@
<div class="layout-navbars-breadcrumb-user-icon" @click="onLayoutSetingClick"> <div class="layout-navbars-breadcrumb-user-icon" @click="onLayoutSetingClick">
<i class="icon-skin iconfont" title="布局配置"></i> <i class="icon-skin iconfont" title="布局配置"></i>
</div> </div>
<div class="layout-navbars-breadcrumb-user-icon" @click="onUserNewsPopoverClick"> <div class="layout-navbars-breadcrumb-user-icon">
<el-popover placement="bottom" trigger="click" v-model:visible="isShowUserNewsPopover" :width="300"> <el-popover placement="bottom" trigger="click" v-model:visible="isShowUserNewsPopover" :width="300"
popper-class="el-popover-pupop-user-news">
<template #reference> <template #reference>
<el-badge :is-dot="true"> <el-badge :is-dot="true">
<i class="el-icon-bell" title="消息"></i> <i class="el-icon-bell" title="消息"></i>
</el-badge> </el-badge>
</template> </template>
<UserNews /> <transition name="el-zoom-in-top">
<UserNews v-show="isShowUserNewsPopover" />
</transition>
</el-popover> </el-popover>
</div> </div>
<div class="layout-navbars-breadcrumb-user-icon mr10" @click="onScreenfullClick"><i class="iconfont" <div class="layout-navbars-breadcrumb-user-icon mr10" @click="onScreenfullClick"><i class="iconfont"
@ -137,10 +140,6 @@ export default {
const onSearchClick = () => { const onSearchClick = () => {
searchRef.value.openSearch(); searchRef.value.openSearch();
}; };
//
const onUserNewsPopoverClick = () => {
state.isShowUserNewsPopover = !state.isShowUserNewsPopover;
};
return { return {
setFlexAutoStyle, setFlexAutoStyle,
getUserInfos, getUserInfos,
@ -148,7 +147,6 @@ export default {
onHandleCommandClick, onHandleCommandClick,
onScreenfullClick, onScreenfullClick,
onSearchClick, onSearchClick,
onUserNewsPopoverClick,
searchRef, searchRef,
...toRefs(state), ...toRefs(state),
}; };

View File

@ -0,0 +1,112 @@
<template>
<div class="awesome-container">
<el-card shadow="hover" :header="`fontawesome 字体图标(自动载入)${sheetsIconList.length - 24}个`">
<el-row class="iconfont-row">
<template v-for="(v,k) in sheetsIconList" :key="k">
<el-col :xs="12" :sm="8" :md="6" :lg="4" :xl="2">
<div class="iconfont-warp">
<div class="flex-margin">
<div class="iconfont-warp-value">
<i :class="v" class="fa"></i>
</div>
<div class="iconfont-warp-label mt10">{{v}}</div>
</div>
</div>
</el-col>
</template>
</el-row>
</el-card>
</div>
</template>
<script lang="ts">
import { toRefs, reactive, nextTick, onMounted } from "vue";
export default {
name: "awesome",
setup() {
const state = reactive({
sheetsIconList: [],
});
// css 使( `iconfont`)
const initGetStyleSheets = () => {
nextTick(() => {
const styles = document.styleSheets;
let sheetsList = [];
for (let i = 0; i < styles.length; i++) {
if (
styles[i].href &&
styles[i].href.indexOf("netdna.bootstrapcdn.com") > -1
) {
sheetsList.push(styles[i]);
}
}
for (let i = 0; i < sheetsList.length; i++) {
for (let j = 0; j < sheetsList[i].cssRules.length; j++) {
if (
sheetsList[i].cssRules[j].selectorText &&
sheetsList[i].cssRules[j].selectorText.indexOf(".fa-") === 0 &&
sheetsList[i].cssRules[j].selectorText.indexOf(",") === -1
) {
state.sheetsIconList.push(
`${sheetsList[i].cssRules[j].selectorText
.substring(1, sheetsList[i].cssRules[j].selectorText.length)
.replace(/\:\:before/gi, "")}`
);
}
}
}
});
};
//
onMounted(() => {
initGetStyleSheets();
});
return {
...toRefs(state),
};
},
};
</script>
<style scoped lang="scss">
.awesome-container {
.iconfont-row {
border-top: 1px solid #ebeef5;
border-left: 1px solid #ebeef5;
.el-col:nth-child(-n + 24) {
display: none;
}
.iconfont-warp {
text-align: center;
border-right: 1px solid #ebeef5;
border-bottom: 1px solid #ebeef5;
height: 120px;
overflow: hidden;
display: flex;
&:hover {
.iconfont-warp-value {
i {
color: var(--color-primary);
transition: all 0.3s ease;
}
}
.iconfont-warp-label {
color: var(--color-primary);
transition: all 0.3s ease;
}
}
.iconfont-warp-value {
i {
color: #606266;
font-size: 32px;
transition: all 0.3s ease;
}
}
.iconfont-warp-label {
color: #99a9bf;
transition: all 0.3s ease;
}
}
}
}
</style>

View File

@ -1,6 +1,6 @@
<template> <template>
<div class="element-container"> <div class="element-container">
<el-card shadow="hover" header="element plus 字体图标(自动载入)"> <el-card shadow="hover" :header="`element plus 字体图标(自动载入)${sheetsIconList.length - 2}个`">
<el-row class="iconfont-row"> <el-row class="iconfont-row">
<template v-for="(v,k) in sheetsIconList" :key="k"> <template v-for="(v,k) in sheetsIconList" :key="k">
<el-col :xs="12" :sm="8" :md="6" :lg="4" :xl="2"> <el-col :xs="12" :sm="8" :md="6" :lg="4" :xl="2">

View File

@ -16,7 +16,8 @@
</div> </div>
<div class="flex-warp mt15 mb15" v-if="tableData.data.length > 0"> <div class="flex-warp mt15 mb15" v-if="tableData.data.length > 0">
<el-row :gutter="15"> <el-row :gutter="15">
<el-col :sm="6" class="mb15" v-for="(v,k) in tableData.data" :key="k" @click="onTableItemClick(v)"> <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb15" v-for="(v,k) in tableData.data" :key="k"
@click="onTableItemClick(v)">
<div class="flex-warp-item"> <div class="flex-warp-item">
<div class="flex-warp-item-box"> <div class="flex-warp-item-box">
<div class="item-img"> <div class="item-img">

View File

@ -1,6 +1,6 @@
<template> <template>
<div class="iconfont-container"> <div class="iconfont-container">
<el-card shadow="hover" header="iconfont 字体图标(自动载入)"> <el-card shadow="hover" :header="`iconfont 字体图标(自动载入)${sheetsIconList.length}个`">
<el-row class="iconfont-row"> <el-row class="iconfont-row">
<el-col :xs="12" :sm="8" :md="6" :lg="4" :xl="2" v-for="(v,k) in sheetsIconList" :key="k"> <el-col :xs="12" :sm="8" :md="6" :lg="4" :xl="2" v-for="(v,k) in sheetsIconList" :key="k">
<div class="iconfont-warp"> <div class="iconfont-warp">