App.vue 655 B

123456789101112131415161718192021222324252627282930
  1. <template>
  2. <transition name="el-fade-in-linear">
  3. <router-view />
  4. </transition>
  5. </template>
  6. <script>
  7. import Cookies from 'js-cookie'
  8. import { messages } from '@/i18n'
  9. export default {
  10. watch: {
  11. '$i18n.locale': 'i18nHandle'
  12. },
  13. created () {
  14. this.i18nHandle(this.$i18n.locale)
  15. },
  16. methods: {
  17. i18nHandle (val, oldVal) {
  18. Cookies.set('language', val)
  19. document.querySelector('html').setAttribute('lang', val)
  20. document.title = messages[val].brand.lg
  21. // 非登录页面,切换语言刷新页面
  22. if (this.$route.name !== 'login' && oldVal) {
  23. window.location.reload()
  24. }
  25. }
  26. }
  27. }
  28. </script>