首页 > 解决方案 > Vue 组件已定义但未使用的错误消息。我该如何正确使用它?

问题描述

作为 Vue.js 的新手,我已经定义并且据我所知,使用了 nav 组件,但是npm run serve不同意。

我得到的确切错误是:

 ERROR  Failed to compile with 1 errors                                                                                                                                                             20:51:39

 error  in ./src/App.vue

Module Error (from ./node_modules/eslint-loader/index.js):
error: The "nav" component has been registered but not used (vue/no-unused-components) at src/App.vue:13:5:
  11 |   name: 'app',
  12 |   components: {
> 13 |     nav,
     |     ^
  14 |   },
  15 | };
  16 | </script>

1 error found.

 @ ./src/main.js 6:0-28 12:13-16
 @ multi (webpack)-dev-server/client?http://192.168.233.240:8080/sockjs-node (webpack)/hot/dev-server.js ./src/main.js

文件布局

src
|
|__assets
|  |__css
|     |__ style.css
|
|__components
|  |__nav.vue
|
|__App.vue
|
|__main.js

应用程序.vue

    <template>
  <div id="app">
    <nav />
  </div>
</template>

<script>
import nav from '@/components/nav.vue';

export default {
  name: 'app',
  components: {
    nav,
  },
};
</script>

main.js 我相信我所做的唯一更改是在bootstrap.css文件中添加。

import Vue from 'vue';
import App from './App.vue';
import 'bootstrap/dist/css/bootstrap.css';

import './assets/css/style.css';

Vue.config.productionTip = false;

new Vue({
  render: (h) => h(App)
}).$mount('#app');

当然,还有模板本身。

    <template>
  <nav class="nav flex-column">
    <a class="nav-link active" href="#">Active</a>
    <a class="nav-link" href="#">Link</a>
    <a class="nav-link" href="#">Link</a>
    <a class="nav-link disabled" href="#" tabindex="-1" aria-disabled="true">Disabled</a>
  </nav>
</template>

<script>

export default {
  name: 'nav',
};
</script>

标签: javascriptvue.jsvue-component

解决方案


您不应该将其称为 nav,因为已经有一个具有此名称的默认 HTML 组件(因为您在实际组件中使用自己)。
将您的组件重命名为 Nav(是的,大写 N),之后它应该可以正常工作。

导航

<template>
  <nav class="nav flex-column">
    <a class="nav-link active" href="#">Active</a>
    <a class="nav-link" href="#">Link</a>
    <a class="nav-link" href="#">Link</a>
    <a class="nav-link disabled" href="#" tabindex="-1" aria-disabled="true">Disabled</a>
  </nav>
</template>

export default {
  name: 'Nav',
};

应用程序.vue

<template>
  <div id="app">
    <Nav />
  </div>
</template>

<script>
import Nav from '@/components/Nav';

export default {
  name: 'app',
  components: {
    Nav,
  },
};
</script>

推荐阅读