123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112 |
- <template>
- <div class="avue-contail"
- :class="{'avue--collapse':isCollapse}">
- <div class="avue-header">
- <!-- 顶部导航栏 -->
- <top/>
- </div>
- <div class="avue-layout">
- <div class="avue-left">
- <!-- 左侧导航栏 -->
- <sidebar/>
- </div>
- <div class="avue-main">
- <!-- 顶部标签卡 -->
- <tags/>
- <!-- 主体视图层 -->
- <el-scrollbar style="height:100%">
- <keep-alive>
- <router-view class="avue-view"
- v-if="$route.meta.$keepAlive"/>
- </keep-alive>
- <router-view class="avue-view"
- v-if="!$route.meta.$keepAlive"/>
- </el-scrollbar>
- </div>
- </div>
- <div class="avue-shade"
- @click="showCollapse"></div>
- </div>
- </template>
- <script>
- import {mapGetters} from 'vuex'
- import tags from './tags'
- import top from './top/'
- import sidebar from './sidebar/'
- import admin from '@/util/admin';
- import {validatenull} from '@/util/validate';
- import {calcDate} from '@/util/date.js';
- import {getStore} from '@/util/store.js';
- export default {
- components: {
- top,
- tags,
- sidebar
- },
- name: 'index',
- data() {
- return {
- //刷新token锁
- refreshLock: false,
- //刷新token的时间
- refreshTime: '',
- }
- },
- created() {
- //实时检测刷新token
- this.refreshToken()
- },
- destroyed() {
- console.log("销毁")
- console.log(this.refreshTime)
- clearInterval(this.refreshTime)
- },
- mounted() {
- this.init()
- },
- computed: mapGetters(['isLock', 'isCollapse', 'website', 'expires_in']),
- props: [],
- methods: {
- showCollapse() {
- this.$store.commit("SET_COLLAPSE")
- },
- // 屏幕检测
- init() {
- this.$store.commit('SET_SCREEN', admin.getScreen())
- window.onresize = () => {
- setTimeout(() => {
- this.$store.commit('SET_SCREEN', admin.getScreen())
- }, 0);
- }
- },
- // 实时检测刷新token
- refreshToken() {
- this.refreshTime = setInterval(() => {
- const token = getStore({
- name: 'access_token',
- debug: true,
- });
- if (validatenull(token)) {
- return;
- }
- if (this.expires_in <= 1000 && !this.refreshLock) {
- this.refreshLock = true
- this.$store
- .dispatch('RefreshToken')
- .catch(() => {
- clearInterval(this.refreshTime)
- });
- this.refreshLock = false
- }
- this.$store.commit("SET_EXPIRES_IN",this.expires_in - 10);
- }, 10000);
- },
- }
- }
- </script>
|