gpt4 book ai didi

javascript - PhantomJS 在 vue 中抛出错误

转载 作者:搜寻专家 更新时间:2023-10-30 22:27:15 25 4
gpt4 key购买 nike

我正在使用 webpack 模板构建一个 vuejs 应用程序。问题是当我尝试运行单元测试时(现在只是默认的...)PhantomJS 抛出这个错误:

PhantomJS 2.1.1 (Mac OS X 0.0.0) ERROR
TypeError: undefined is not a constructor (evaluating 'val.toLowerCase()')
at webpack:///~/vue/dist/vue.esm.js:89:0 <- index.js:13783

错误指的是 Vue 库,因此应用程序的代码肯定有问题。一些上下文:我正在创建 vue 组件的展示,所以我将 webpack 配置为在构建的产品中跳过很多文件/文件夹,因为它们只是组件的展示,而我只想要我的产品中的核心组件构建。

所以结构文件夹如下:

src
|----components
|----main.js
|----assets.js
|----App.vue
|----core
|----coreComponents
|----mainProdBuilder.js
|----coreAssets.js

如果我导入所有组件,并且如果我将所有内容都与“main.js”作为入口点捆绑在一起,我可以毫无问题地运行测试,但是,一旦我尝试使用 mainProdBuilder 脚本来捆绑生产文件,我就会得到错误。这是脚本:

import Vue from "vue";

import MyTable from "./Table/Table";
import FormatNumber from "./numberFormatting";
import TotalValue from "./TotalValue";
import MyTitle from "./Title/Title";
import TestTitle from "./Title/TestTitle";
import BarChart from "./Charts/BarChart";
import Histogram from "./Charts/Histogram";

Vue.component(MyTable,
MyTitle,
TestTitle,
BarChart,
TotalValue,
Histogram,
);

请注意,如果我评论所有 vue 组件,一次只留下一个组件,它会起作用。因此,例如这有效:

import Vue from "vue";

import MyTable from "./Table/Table";

Vue.component(
MyTable,
);

这也有效:

import Vue from "vue";

import Histogram from "./Charts/Histogram";

Vue.component(
Histogram,
);

但这会引发错误:

import Vue from "vue";

import MyTable from "./Table/Table";
import Histogram from "./Charts/Histogram";

Vue.component(
MyTable,
Histogram
);

我错过了什么?

最佳答案

Vue.component() 接受一个id(即组件的名称)和一个对象定义,你不能注册你所有的全局组件在一起(虽然你可以为本地组件做),你需要单独注册它们:

import MyTable from "./Table/Table";
import FormatNumber from "./numberFormatting";
//etc...

Vue.component('my-table', MyTable);
Vue.component('format-number', FormatNumber);
//etc...

如果你尝试使用一个 Vue.component 注册它们,你会得到你收到的错误,你可以在 this JSFiddle 中看到。

关于javascript - PhantomJS 在 vue 中抛出错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44545497/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com