App.vue 12.8 KB
Newer Older
yma16's avatar
yma16 已提交
1
<template>
Y
yma16 已提交
2
  <div id="app">
yma16's avatar
yma16 已提交
3
    <el-container>
yma16's avatar
yma16 已提交
4
      <el-aside v-if="!navigate_flag">
Y
yma16 已提交
5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
        <router-link to="/">
          <svg
            class="icon"
            aria-hidden="true"
            style="width: auto; height: auto; padding-top: 5%"
          >
            <use xlink:href="#iconshejitouxiangai"></use>
          </svg>
        </router-link>
        <el-menu
          default-active=""
          class="el-menu-vertical-demo"
          @open="handleOpen"
          @close="handleClose"
        >
          <el-submenu index="1">
            <template slot="title">
              <i class="el-icon-user-solid"></i>
              <span slot="title">开发人员</span>
            </template>
            <el-menu-item-group>
              <el-submenu index="1-1">
yma16's avatar
yma16 已提交
27 28
                <template slot="title"
                  >yma16
yma16's avatar
yma16 已提交
29
                  </template
yma16's avatar
yma16 已提交
30
                >
Y
yma16 已提交
31
                <el-menu-item index="1-1-1">stay hungry</el-menu-item>
yma16's avatar
yma16 已提交
32
                <a @click="jumpToEcharts">
Y
yma16 已提交
33 34
                  <el-menu-item index="1-1-2">echarts</el-menu-item>
                </a>
yma16's avatar
yma16 已提交
35
                <a @click="jumpToAdmin">
Y
yma16 已提交
36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
                  <el-menu-item index="1-1-3">superuser</el-menu-item>
                </a>
              </el-submenu>
              <el-submenu index="1-2">
                <template slot="title">location</template>
                <el-menu-item index="1-2-1" @click="jumpRouter('Home')"
                  >guiyang</el-menu-item
                >
              </el-submenu>
            </el-menu-item-group>
          </el-submenu>

          <el-submenu index="2">
            <template slot="title">
              <i class="el-icon-setting"></i>管理后台</template
            >
            <el-menu-item-group>
              <el-submenu index="2-1">
                <template slot="title">登录</template>
              </el-submenu>
              <el-submenu index="2-2">
                <template slot="title">注册</template>
              </el-submenu>
            </el-menu-item-group>
          </el-submenu>

          <el-submenu index="3">
            <template slot="title">
yma16's avatar
yma16 已提交
64
              <i class="el-icon-chat-line-round" :click="onlineWebsocket"></i
Y
yma16 已提交
65 66 67 68 69 70 71 72 73 74 75 76 77 78
              >线上聊天</template
            >
          </el-submenu>
        </el-menu>
      </el-aside>

      <el-container>
        <el-header>
          <a v-on:click="changeNavigate" style="cursor: pointer"
            ><i class="el-icon-s-promotion"></i>&nbsp;&nbsp;<span
              style="font-weight: bold"
              >{{ authSlogan }}</span
            ></a
          >
yma16's avatar
yma16 已提交
79 80 81
<!--          <i style="font-weight: bold; font-style: normal" v-if="chat_flag"-->
<!--            >&nbsp;&nbsp;在线聊天室</i-->
<!--          >-->
yma16's avatar
yma16 已提交
82
          <div style="float: right; overflow: hidden;display: flex;justify-items: center;align-items:center;word-spacing: 16px;">
yma16's avatar
yma16 已提交
83 84 85 86 87 88 89 90 91 92
            <span style="cursor: pointer; width: 80px" v-if="currentUserName">
              <el-popover
                trigger="click">
                <span @click="loginOut" style="cursor: pointer; height: 16px">注销</span>
  <template slot="reference">
    <i class="el-icon-user" style="font-weight: 300">{{currentUserName}}</i>
  </template>
</el-popover>

            </span>
Y
yma16 已提交
93 94 95
            <a href="https://codechina.csdn.net/qq_38870145/myblogvue"
              ><img
                src="@/assets/img/code-china.png"
yma16's avatar
yma16 已提交
96
                style="cursor: pointer; height: 16px"
Y
yma16 已提交
97
            /></a>
yma16's avatar
yma16 已提交
98

Y
yma16 已提交
99 100 101
            <a href="https://github.com/yongma16"
              ><img
                src="@/assets/img/github-fill.png"
yma16's avatar
yma16 已提交
102
                style="cursor: pointer; height: 16px"
Y
yma16 已提交
103
            /></a>
yma16's avatar
yma16 已提交
104

Y
yma16 已提交
105 106 107 108 109 110 111 112 113 114 115
          </div>

          <!-- <a v-on:click="changeNavigate"><i class="el-icon-menu"></i></a> -->
        </el-header>

        <el-main id="mainappid" class="mainappclass">
          <!-- 路由 -->
          <router-view />
        </el-main>

        <el-footer>
yma16's avatar
yma16 已提交
116 117 118 119
          <div class="design-footer">
            <div class="footer_font">
              <div style="float: left"></div>
              <span>
120 121
                Copyright &copy;{{startTime}} yongma16.xyz
                个人空间&nbsp;&nbsp;&nbsp;</span>
yma16's avatar
yma16 已提交
122 123 124 125 126 127 128 129 130 131 132
              <span> 足迹:{{ readCount }}&nbsp;&nbsp;&nbsp;</span>
              <span
                ><img
                  src="@/assets/img/badge.png"
                  style="
                    cursor: pointer;
                    height: 16px;
                    margin-bottom: 0;
                    padding-bottom: 0;
                  "
                />&nbsp;&nbsp;<span style="cursor: pointer" @click="jumpIpDns"
133
                  >黔ICP备20001426号-1</span></span>
yma16's avatar
yma16 已提交
134 135
            </div>
            <!--            <div></div>-->
Y
yma16 已提交
136 137 138
          </div>
        </el-footer>
      </el-container>
yma16's avatar
yma16 已提交
139
    </el-container>
Y
yma16 已提交
140
  </div>
yma16's avatar
yma16 已提交
141 142 143
</template>

<script>
yma16's avatar
yma16 已提交
144
import store from '@/store'
yma16's avatar
yma16 已提交
145
export default {
yma16's avatar
yma16 已提交
146 147 148
    name: 'App',
    data () {
        return {
149 150
            // 开始时间
            startTime: '',
yma16's avatar
yma16 已提交
151 152 153 154 155 156 157 158 159 160 161 162 163 164 165
            authSlogan: 'yma16',
            chat_flag: false,
            msg: 'yma16',
            navigate_flag: true,
            value: new Date(),
            baseUrl: '/api/',
            src: 'https://cube.elemecdn.com/6/94/4d3ea53c084bad6931a56d5158a48jpeg.jpeg',
            url: '/image/logo/logo.jpg',
            srcList: [
                'https://fuss10.elemecdn.com/8/27/f01c15bb73e1ef3793e64e6b7bbccjpeg.jpeg',
                'https://fuss10.elemecdn.com/1/8e/aeffeb4de74e2fde4bd74fc7b4486jpeg.jpeg'
            ],
            headerData: ['从现在开始,种一棵树', '从现在开始,种一棵树'],
            readCount: 0
        }
yma16's avatar
yma16 已提交
166
    },
yma16's avatar
yma16 已提交
167 168 169 170
    computed: {
        currentUserName: function () {
            return store.state.user.userInfo && store.state.user.userInfo.name
                ? store.state.user.userInfo.name
yma16's avatar
yma16 已提交
171
                : ''
yma16's avatar
yma16 已提交
172
        }
yma16's avatar
yma16 已提交
173
    },
yma16's avatar
yma16 已提交
174
    mounted () {
175
        this.initStartTime()
yma16's avatar
yma16 已提交
176 177
        this.addReadCountFun()
        this.readCountFun()
Y
yma16 已提交
178
    },
yma16's avatar
yma16 已提交
179
    methods: {
180 181 182 183 184
        initStartTime () {
            const now = new Date()
            const year = now.getFullYear()
            this.startTime = `2021-${year}`
        },
yma16's avatar
yma16 已提交
185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222
        jumpIpDns: function () {
            try {
                window.open('https://beian.miit.gov.cn')
            } catch (r) {
                window.location.href = 'https://beian.miit.gov.cn'
                throw Error(r)
            }
        },
        addReadCountFun: function () {
            const that = this
            let clientIp = '未知'
            try {
                console.warn('ip待定')
            } catch (e) {
                console.warn(e)
            }
            that.$axios
                .post(this.baseUrl + 'count/add/', {
                    ip: clientIp
                })
                .catch((e) => {
                    throw Error(e)
                })
        },
        readCountFun: function () {
            let that = this
            that.$axios
                .get(that.baseUrl + 'count/get/')
                .then((res) => {
                    this.readCount = res.data.num
                })
                .catch((error) => {
                    throw Error(error)
                })
        },
        changeNavigate: function () {
            this.navigate_flag = !this.navigate_flag // 取反
        },
Y
yma16 已提交
223

yma16's avatar
yma16 已提交
224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296
        handleOpen (key, keyPath) {
            if (key === '3') {
                this.chat_flag = true
                this.onlineWebsocket() // 调用跳转
            }
            if (key === '2-1') {
                this.chat_flag = false
                this.loginAction() // 调用跳转
            }
            if (key === '2-2') {
                this.chat_flag = false
                this.registerAction() // 调用跳转
            }
        },
        handleClose (key, keyPath) {
            console.info(key, keyPath)
            if (key === '3') {
                this.chat_flag = false
            }
        },
        jumpRouter: function (params) {
            this.$router
                .push({
                    name: `${params}`
                })
                .catch((error) => {
                    throw Error(error)
                })
        },
        onlineWebsocket: function () {
            this.$router
                .push({
                    path: '/onlinewebsocket'
                })
                .catch((error) => {
                    throw Error(error)
                })
        },
        jumpToEcharts: function () {
            this.$router
                .push({
                    path: '/bilicom'
                })
                .catch((error) => {
                    throw Error(error)
                })
        },
        jumpToAdmin: function () {
            this.$router
                .push({
                    path: '/mavoneditor'
                })
                .catch((error) => {
                    throw Error(error)
                })
        },
        loginAction: function () {
            this.$router
                .push({
                    path: '/login'
                })
                .catch((error) => {
                    throw Error(error)
                })
        },
        registerAction: function () {
            this.$router
                .push({
                    path: '/register'
                })
                .catch((error) => {
                    throw Error(error)
                })
yma16's avatar
yma16 已提交
297 298 299 300
        },
        loginOut () {
            localStorage.removeItem('yma16siteUserInfo')
            window.location.reload()
yma16's avatar
yma16 已提交
301 302 303
        }
    }
}
yma16's avatar
yma16 已提交
304 305 306 307 308 309 310
</script>

<style>
html,
body,
#app,
.el-container {
Y
yma16 已提交
311 312 313 314
  margin: 0px;
  padding: 0%;
  border: 0px;
  height: 100%;
yma16's avatar
yma16 已提交
315
  /* background: url(../myblog_static/utils/fx_background/image/gg.jpg) center top no-repeat; */
Y
yma16 已提交
316
  /* background: url(/image/snow/gg.jpg) center top no-repeat; */
yma16's avatar
yma16 已提交
317 318 319
}

body {
Y
yma16 已提交
320 321
  background-color: #2f214b;
  /* background: url(/image/snow/gg.jpg) center top no-repeat; */
yma16's avatar
yma16 已提交
322 323 324
}

.el-header {
Y
yma16 已提交
325 326 327 328 329
  background-color: #d4beb4;
  /* color: rgb(48, 76, 77); */
  text-align: left;
  line-height: 60px;
  /* background: url(/image/snow/gg.jpg) center top no-repeat; */
yma16's avatar
yma16 已提交
330 331
}

yma16's avatar
yma16 已提交
332 333 334 335 336
.design-footer {
  position: relative;
  margin-top: 20px;
}

yma16's avatar
yma16 已提交
337
.footer_font {
Y
yma16 已提交
338 339
  position: relative;
  /* height: 100%; */
yma16's avatar
yma16 已提交
340 341 342
}

.el-footer {
Y
yma16 已提交
343 344 345 346 347 348
  height: 100%;
  background-color: #bba8a4;
  color: #333;
  text-align: center;
  /* line-height: 60px; */
  box-sizing: border-box;
yma16's avatar
yma16 已提交
349 350 351
}

.el-aside {
Y
yma16 已提交
352 353 354 355 356 357
  background-color: #be9a90;
  color: #333;
  text-align: center;
  line-height: 80px;
  width: 80px;
  min-height: 60px;
yma16's avatar
yma16 已提交
358 359 360
}

.activeleft {
Y
yma16 已提交
361 362
  transform: translateX(-100vw);
  /* 左移100 */
yma16's avatar
yma16 已提交
363 364 365
}

.activeright {
Y
yma16 已提交
366 367
  transform: translateX(100vw);
  /* 右移100 */
yma16's avatar
yma16 已提交
368 369 370
}

.el-main {
Y
yma16 已提交
371 372 373
  /* background-color: #e9eef3; */
  text-align: left;
  opacity: 1;
yma16's avatar
yma16 已提交
374
  /* background: url(../myblog_static/utils/fx_background/image/gg.jpg) center top no-repeat; */
Y
yma16 已提交
375 376
  margin: 0;
  padding: 0;
yma16's avatar
yma16 已提交
377 378 379
}

.mainappclass {
Y
yma16 已提交
380 381 382
  margin: 0;
  padding: 0;
  overflow: auto;
yma16's avatar
yma16 已提交
383 384 385
}

.mainappclass::-webkit-scrollbar {
Y
yma16 已提交
386
  display: none;
yma16's avatar
yma16 已提交
387 388
}

Y
yma16 已提交
389 390 391 392 393
body > .el-container {
  color: #475669;
  opacity: 0.5;
  padding: 0%;
  margin-bottom: 40px;
yma16's avatar
yma16 已提交
394 395 396 397
}

.el-container:nth-child(5) .el-aside,
.el-container:nth-child(6) .el-aside {
Y
yma16 已提交
398
  line-height: 260px;
yma16's avatar
yma16 已提交
399 400 401
}

.el-container:nth-child(7) .el-aside {
Y
yma16 已提交
402
  line-height: 320px;
yma16's avatar
yma16 已提交
403 404 405
}

.el-carousel__item h3 {
Y
yma16 已提交
406 407 408 409 410
  color: #475669;
  font-size: 14px;
  opacity: 0.5;
  line-height: 150px;
  margin: 0;
yma16's avatar
yma16 已提交
411 412 413
}

.el-carousel__item:nth-child(2n) {
Y
yma16 已提交
414 415
  /* background-image: url("/image/navigation/previewFix.jpg"); */
  transition-duration: 2s;
yma16's avatar
yma16 已提交
416 417 418
}

.el-carousel__item:nth-child(2n + 1) {
Y
yma16 已提交
419 420
  /* background-image: url("/image/navigation/original.jpg"); */
  transition-duration: 2s;
yma16's avatar
yma16 已提交
421 422 423
}

.footerclass {
Y
yma16 已提交
424 425
  position: relative;
  display: flex;
yma16's avatar
yma16 已提交
426 427 428
}

.midfooter {
Y
yma16 已提交
429 430 431 432
  position: relative;
  left: 50%;
  top: 50%;
  transform: translateX(-50%, -50%);
yma16's avatar
yma16 已提交
433 434 435
}

.heart {
Y
yma16 已提交
436 437 438 439 440 441 442 443
  width: 30px;
  height: 30px;
  position: relative;
  background: pink;
  transform: rotate(45deg);
  animation-name: change;
  animation-duration: 2s;
  animation-iteration-count: infinite;
yma16's avatar
yma16 已提交
444 445 446
}

.heart::before {
Y
yma16 已提交
447 448 449 450 451 452 453
  content: "";
  width: 30px;
  height: 30px;
  background: pink;
  border-radius: 50%;
  position: absolute;
  transform: translateX(-15px);
yma16's avatar
yma16 已提交
454 455 456
}

.heart::after {
Y
yma16 已提交
457 458 459 460 461 462 463 464 465
  content: "";
  width: 30px;
  height: 30px;
  background: pink;
  border-radius: 50%;
  position: absolute;
  /* 定位 */
  transform: translate(0px, -15px);
  /* transform: translateX(-100px); */
yma16's avatar
yma16 已提交
466 467 468
}

@keyframes change {
Y
yma16 已提交
469 470 471
  0% {
    transform: rotate(45deg) scale(0.25);
  }
yma16's avatar
yma16 已提交
472

Y
yma16 已提交
473 474 475
  50% {
    transform: rotate(45deg) scale(0.5);
  }
yma16's avatar
yma16 已提交
476

Y
yma16 已提交
477 478 479
  100% {
    transform: rotate(45deg) scale(0.25);
  }
yma16's avatar
yma16 已提交
480
}
yma16's avatar
yma16 已提交
481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501
::-webkit-scrollbar {
  width: 10px;
  /* height:5px; */
  /* display: none; */
}
::-webkit-scrollbar-track {
  background: rgba(226, 247, 255, 0.5);
  border-radius: 2px;
  /* display: none; */
}
::-webkit-scrollbar-track-piece {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 2px;
  /* display: none; */
}
::-webkit-scrollbar-thumb {
  background: #ff995e;
  height: 2px;
  border-radius: 2px;
  /* display: none; */
}
yma16's avatar
yma16 已提交
502
@keyframes backdiv {
Y
yma16 已提交
503 504 505
  50% {
    background: #ffe6f2;
  }
yma16's avatar
yma16 已提交
506 507
}
</style>