vue3.x:报错记录清单

当使用vue/cli-plugin-eslintv7.20.0及以上版本时,由于引入了vue/multi-word-component-names规则,单单词的组件名会导致编译错误。解决方法包括修改组件名为多单词(如大驼峰或小驼峰),关闭eslint的lintOnSave设置,或者在.vue.config.js和.eslintrc.js中关闭或忽略特定的命名规则。

##报错提示

component name “index“ should always be multi-word

在组件命名的时候不够规范,根据官方风格指南,除了根组件(App.vue)外,自定义组件名称应该由多单词组成,防止和html标签冲突。vue-cli创建的项目使用了最新的vue/cli-plugin-eslint插件,在vue/cli-plugin-eslint v7.20.0版本之后就引用了vue/multi-word-component-names规则,所以在编译的时候判定此次错误。

解决方式

1. 修改文件名称
修改组件名为多个单词,使用大驼峰或是小驼峰命名规则。
2. 关闭eslint校验
在根目录下找到vue.config.js文件(如果没有则新建一个),添加下面的代码:

const { defineConfig } = require('@vue/cli-service')
module.exports = defineConfig({
  transpileDependencies: true,
  // 添加此行代码
  lintOnSave:false
})

3. 关闭命名规则校验
在根目录下找到 .eslintrc.js 文件,同样如果没有则新建一个(注意文件前有个点),添加下面的代码:

    "vue/multi-word-component-names":"off",

示例如下:

module.exports = {
  root: true,
  env: {
    node: true
  },
  'extends': [
    'plugin:vue/essential',
    'eslint:recommended'
  ],
  parserOptions: {
    parser: '@babel/eslint-parser'
  },
  rules: {
    'no-console': process.env.NODE_ENV === 'production' ? 'warn' : 'off',
    'no-debugger': process.env.NODE_ENV === 'production' ? 'warn' : 'off',
     //  在rules中添加自定义规则
    //  关闭组件命名规则
     "vue/multi-word-component-names":"off",
  },
  overrides: [
    {
      files: [
        '**/__tests__/*.{j,t}s?(x)',
        '**/tests/unit/**/*.spec.{j,t}s?(x)'
      ],
      env: {
        jest: true
      }
    }
  ]
}
 

4. 官方建议忽略个别组件名

module.exports = {
  root: true,
  env: {
    node: true
  },
  'extends': [
    'plugin:vue/essential',
    'eslint:recommended'
  ],
  parserOptions: {
    parser: '@babel/eslint-parser'
  },
  rules: {
    'no-console': process.env.NODE_ENV === 'production' ? 'warn' : 'off',
    'no-debugger': process.env.NODE_ENV === 'production' ? 'warn' : 'off',
     //  在rules中添加自定义规则
    //  添加组件命名忽略规则
    "vue/multi-word-component-names": ["error",{
       //  需要忽略的组件名
       "ignores": ["index"]
    }]
  },
  overrides: [
    {
      files: [
        '**/__tests__/*.{j,t}s?(x)',
        '**/tests/unit/**/*.spec.{j,t}s?(x)'
      ],
      env: {
        jest: true
      }
    }
  ]
}
- D:\coderepository\mini-program\save-quick-spirit-applet\vue.config.js [HBuilder] 16:12:38.686 - D:\BaiduNetdiskDownload\3.6.18\HBuilderX\plugins\uniapp-cli\node_modules\@vue\cli-service\lib\Service.js [HBuilder] 16:12:38.690 - D:\BaiduNetdiskDownload\3.6.18\HBuilderX\plugins\uniapp-cli\bin\uniapp-cli.js [HBuilder] 16:12:38.694 Error: Cannot find module &#39;uni-read-pages&#39; [HBuilder] 16:12:38.699 Require stack: [HBuilder] 16:12:38.702 - D:\coderepository\mini-program\save-quick-spirit-applet\vue.config.js [HBuilder] 16:12:38.705 - D:\BaiduNetdiskDownload\3.6.18\HBuilderX\plugins\uniapp-cli\node_modules\@vue\cli-service\lib\Service.js [HBuilder] 16:12:38.709 - D:\BaiduNetdiskDownload\3.6.18\HBuilderX\plugins\uniapp-cli\bin\uniapp-cli.js [HBuilder] 16:12:38.714 at Function.Module._resolveFilename (node:internal/modules/cjs/loader:956:15) [HBuilder] 16:12:38.715 at Function.Module._resolveFilename (D:\BaiduNetdiskDownload\3.6.18\HBuilderX\plugins\uniapp-cli\node_modules\module-alias\index.js:49:29) [HBuilder] 16:12:38.720 at Function.Module._load (node:internal/modules/cjs/loader:804:27) [HBuilder] 16:12:38.724 at Module.require (node:internal/modules/cjs/loader:1028:19) [HBuilder] 16:12:38.729 at require (node:internal/modules/cjs/helpers:102:18) [HBuilder] 16:12:38.733 at Object.<anonymous> (D:\coderepository\mini-program\save-quick-spirit-applet\vue.config.js:1:24) [HBuilder] 16:12:38.736 at Module._compile (node:internal/modules/cjs/loader:1126:14) [HBuilder] 16:12:38.740 at Object.Module._extensions..js (node:internal/modules/cjs/loader:1180:10) [HBuilder] 16:12:38.743 at Module.load (node:internal/modules/cjs/loader:1004:32) [HBuilder] 16:12:38.747 at Function.Module._load (node:internal/modules/cjs/loader:839:12) [HBuilder] 16:12:38.751 项目 &#39;save-quick-spirit-applet&#39; 发布微信小程序失败. 为什么npm install没有安装到这些依赖
最新发布
09-02
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值