目录

解决vue3使用iconpark控制台预警提示问题

前言

最近在项目中使用 iconpark-icon 来管理图标,一切都很顺利,引入链接后,图标正常显示,没有报错。但是控制台却发出了预警信息。

[Vue warn]: Failed to resolve component: iconpark-icon If this is a native custom element, make sure to exclude it from component resolution via compilerOptions.isCustomElement.

虽说不影响使用,但看着着实难受,于是研究了一下,成功解决预警提示。

解决办法

首先看一下警告内容,这个警告的意思是 Vue.js 无法找到名为 "iconpark-icon" 的组件。可能造成这个问题的原因是组件没有被正确地注册或者导入。

看完警告信息后,解决办法就很简单了,只要告诉 Vue"iconpark-icon" 是什么或者让其忽略这个检查即可。关于这一点,iconpark 的文档中是有说明的 IconPark 图标在线链接功能使用指南

可惜的是第一种方法经验证,无效(×)。

javascript 复制代码
app.config.compilerOptions.isCustomElement = tag => tag === 'iconpark-icon';

更可惜的是,Vue3 项目,基本都是 TS + Vite 技术栈开发,所以第二种针对 webpack 的方法,依然无效(×)。不过代码先放出来,或许也有采用webpack 打包工具的。

javascript 复制代码
// 如果是通过vue-cli, 在vue.config.js中配置
module.exports = {
    chainWebpack: config => {
      config.module
        .rule('vue')
        .use('vue-loader')
          .tap(options => {
              options.compilerOptions = options.compilerOptions || {};
              options.compilerOptions.isCustomElement = tag => tag === 'iconpark-icon'
            // modify the options...
            return options
          })
    }
}

到了这个时候,当然得去 Vue 官网 看看,对此有没有介绍。

果然,官网对此也是有说明的。

javascript 复制代码
// 将所有标签前缀为 `ion-` 的标签视为自定义元素
app.config.compilerOptions.isCustomElement = (tag) => {
  return tag.startsWith('ion-')
}

不过此方法跟 iconpark 的方法一致,不适用于 vue3 + ts + vite 技术栈。所以只能再去 vite 官网看看了,但是很可惜,我并没有找到相关的描述。到此所有捷径都已经走完,只有最后的办法了,自己去解决它。

好在有 webpack 可以参照,因此解决起来并没有花费多久,只在细节上做些修改即可。

所以,真正的解决办法是:在 vite.config.ts 中添加以下代码

javascript 复制代码
export default defineConfig({
  plugins: [
    vue({
      template: {
        compilerOptions: {
          isCustomElement: (tag) => tag.startsWith('iconpark-')
        }
      }
    }),
  ],
})

只需要加上这么一块内容,即可消除警报。

END

本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
那小孩儿2 分钟前
还在每次都写判断?试试惰性函数,让你的代码更聪明!
前端·javascript
朝朝朝朝ZZZ2 分钟前
2025年 npm淘宝镜像最新地址
前端·npm·node.js
maybe020911 分钟前
使用 node.js 和 MongoDB 编写一个简单的增删改接口 demo
前端·数据库·mongodb·node.js
用户725264966296913 分钟前
Cesium:加载本地高程/地形数据
javascript
一只小风华~13 分钟前
HTML5笔记: 什么是HTML
前端·html·html5
ayyo_cici14 分钟前
超快速、不依赖 Docker 的 Next.js 国内部署静态网站方案
前端·next.js
白杨木影子被拉长15 分钟前
长列表优化
vue.js
溪饱鱼15 分钟前
旧饭新炒,有用的React源码-队列机制
前端·react.js·源码阅读
某哈压力大15 分钟前
PC上拉滚动优化
前端·vue.js·react.js
江城开朗的豌豆17 分钟前
CSS篇:前端干货!1分钟分清rem、em、vw和%的区别✨
前端·css·面试