首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >自动路由模块

自动路由模块
EN

Stack Overflow用户
提问于 2019-08-09 11:18:13
回答 1查看 500关注 0票数 0

我已经成功地为vuex存储文件创建了一个自动加载程序,但是我无法让它对vue路由器文件起作用。

我总是得到错误的[vue-router] "path" is required in a route configuration.

index.js自动文件

代码语言:javascript
复制
import camelCase from 'lodash/camelCase';

const requireRoute = require.context('.', false, /\.js$/); // extract js files inside modules folder
const routes = {};

requireRoute.keys().forEach((fileName) => {
  if (fileName === './index.js') return; // reject the index.js file

  const routeName = camelCase(fileName.replace(/(\.\/|\.js)/g, '')); //

  routes[routeName] = requireRoute(fileName).default;
});

export default routes;

router.js

代码语言:javascript
复制
import Vue from 'vue';
import Router from 'vue-router';
import Home from '../views/Home.vue';

import routes from '@/routes/modules';

Vue.use(Router);

export default new Router({
  mode: 'history',
  base: process.env.BASE_URL,
  routes: [
    {
      path: '/',
      name: 'home',
      component: Home,
      meta: {
        icon: 'fa-tachometer',
        title: 'Dashboard',
        inMenu: true,
      },
    },
    routes,
  ],
});

谁能给我指明正确的方向?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-08-14 12:54:20

我必须设置const routes = [];,并必须将其设置为数组。

因此,以下代码起作用:

index.js

代码语言:javascript
复制
const requireRoute = require.context('.', false, /\.js$/); // extract js files inside modules folder
const routes = [];

requireRoute.keys().forEach((fileName) => {
  if (fileName === './index.js') return; // reject the index.js file

  routes.push(requireRoute(fileName).default);
});

export default routes;

router.js

代码语言:javascript
复制
import Vue from 'vue';
import Router from 'vue-router';

import routes from '@/routes/modules';

Vue.use(Router);

export default new Router({
  mode: 'history',
  base: process.env.BASE_URL,
  routes,
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57428944

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档