Vue Router 4 白屏

发布于 2022-09-13 00:55:47 字数 2299 浏览 8 评论 0

一、问题描述

我用npm init vite@latest创建了一个vue-ts项目。安装了vue-router@4,参考文档编写了代码,但是运行之后的页面是白屏

二、相关代码

// src\router\index.ts
import VueRouter from 'vue-router';

// 1. 定义路由组件.
// 也可以从其他文件导入
const Home = { template: '<div>Home</div>' };
const About = { template: '<div>About</div>' };

// 2. 定义一些路由
// 每个路由都需要映射到一个组件。
// 我们后面再讨论嵌套路由。
const routes = [
  { path: '/', component: Home },
  { path: '/about', component: About },
];

// 3. 创建路由实例并传递 `routes` 配置
// 你可以在这里输入更多的配置,但我们在这里
// 暂时保持简单
const router = VueRouter.createRouter({
  // 4. 内部提供了 history 模式的实现。为了简单起见,我们在这里使用 hash 模式。
  history: VueRouter.createWebHashHistory(),
  routes, // `routes: routes` 的缩写
});

export default router;
// src\main.ts
import { createApp } from 'vue';
import App from './App.vue';
import router from './router';

createApp(App).use(router).mount('#app');
<template>
  <!-- src\App.vue -->
  <img alt="Vue logo" src="./assets/logo.png" />
  <HelloWorld msg="Hello Vue 3 + TypeScript + Vite" />

  <!-- 路由出口 -->
  <!-- 路由匹配到的组件将渲染在这里 -->
  <router-view></router-view>
</template>

<script lang="ts">
import { defineComponent } from 'vue';
import HelloWorld from './components/HelloWorld.vue';

export default defineComponent({
  name: 'App',
  components: {
    HelloWorld,
  },
});
</script>

<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

三、解决方法

HaiWeiLian的回答,可以解决我的问题。
对于vue-router没有默认导出的问题,我和HaiWeiLian的解决方法,是一样的。
对于默认不支持运行时编译的问题,我是这样解决的。

import { defineConfig } from 'vite';
import vue from '@vitejs/plugin-vue';

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [vue()],
  resolve: {
    alias: {
      vue: 'vue/dist/vue.esm-bundler.js',
    },
  },
});

我在vite.config.ts中,增加了resolve.alias.vue,使其支持了运行时编译。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

策马西风 2022-09-20 00:55:47

1、最新没有默认导出的,全部是 export, 所以你应该使用。

https://github.com/vuejs/vue-...

import {createRouter, createWebHashHistory} from 'vue-router';

2、其次默认不支持运行时编译,也就是 template 是字符串。

https://v3.cn.vuejs.org/guide...

import { render, h } from 'vue'
const Home = { 
  render() {
    return h('div', null, 'Home')
  }
};

补充:

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文