关于npmlink的问题

深入浅出关于Npm linl的问题

关键词:

vue3报错 Uncaught TypeError: Cannot read properties of null (reading 'isCE') at renderSlot

npm link 无法实现热更新

我的开发环境是

"vue": "^3.2.13"

今天在使用 rollup搭建组件库的时候我发现我的组件库不能实现热更新 我本地的项目是通过npm link去链接到 我本地打包的ui libs 为啥不能热更新呢 大家可以看看我上一篇文章 我当时是在组件库的vue组件中使用了插槽 当我一旦使用了插槽 如果不对webpack进行配置 他会给我报错 报什么错位大家可以看一下;这个文章记录的很详细

我的问题跟他不能说很像只能说一毛一样

复制代码
https://cloud.tencent.com/developer/ask/sof/106913760/answer/132194925

这里 我再废话一下 我怕文章链接失效

大致的问题就是我使用了插槽 打包后 引入我的组件库就会报错

当我把slot注释掉 页面又可以运行了 大致锁定了问题我就开始找解决方法

最终我的解决方案是:

在vue.config.js中添加如下配置

复制代码
const { defineConfig } = require('@vue/cli-service')
const path = require("path");
module.exports = defineConfig({
  transpileDependencies: true,
  configureWebpack: {
   // 👇🏻 这个配置
   resolve: {
     symlinks: false,//留意一下这里
      alias: {
        vue: path.resolve("./node_modules/vue"),
     },
    },
  },
  /* 
  这段代码是在webpack配置文件中的resolve字段中,用于解析模块的路径配置。具体解释如下:
 symlinks: false表示不解析符号链接,即webpack不会对项目中的符号链接进行处理。
 alias用于创建别名,将某个模块的路径映射到另一个路径上,这里是将"vue"模块的路径映射到node_modules/vue目录下。
 这样在项目中引用vue模块时,直接使用import Vue from "vue"即可,而不需要指定完整的路径。
  */
})

问题的原因是什么?

造成这个的原因是有两个不同的vue版本, 就可能下载的其他的第三方和当前的vue版本不相同, 就有两个vue的副本,在引入的时候, npm去尝试引入的地址不对

解决方案

  • 1.由于npm的引入地址不对, 那我们使用yarn,删除node_modules,使用yarn安装,生成新的yarn.lock 然后执行安装

  • 2.修改配置文件

    复制代码
    vite搭建的项目,在 vite.confg.js 文件中添加如下配置:
     resolve: {
    	  dedupe: [
    	    'vue'
    	  ]
    },
    
    webpack(vue-cli)搭建的项目,在vue.config.js文件中添加如下配置:
    const { defineConfig } = require('@vue/cli-service')
    const path = require("path");
    module.exports = defineConfig({
      transpileDependencies: true,
      configureWebpack: {
        resolve: {
          symlinks: true,
          alias: {
            vue: path.resolve("./node_modules/vue"),
          },
        },
      },
    })

    到这里 问题确实解决了 slot也能使用了

    但是的的rollup热更新没法用了

    最开始我是以为是npm link的问题 经过查看源码确定不是npm link的问题

    什么问题呢 symlinks: false,

但是的的rollup热更新没法用了

最开始我是以为是npm link的问题 经过查看源码确定不是npm link的问题

什么问题呢 symlinks: false,

symlinks: false表示不解析符号链接 意思就是你link进来的包 我不管我不解析 这怎么行所以我们把他改成 true 表示我们需要解析这个文件 完美解决 热更新和不能使用插槽问题!

相关推荐
thatway19896 小时前
闲聊-关于AI终结者的警醒
前端
努力的小郑6 小时前
突发!Claude Code 51万行源码全网裸奔:一场史诗级“开源”事故,国内大厂笑麻了
前端·后端·ai编程
七度黑光6 小时前
用 openclaw 给故障复盘打分:质量审核自动化实践
运维·服务器·前端·数据库·自动化
HashTang6 小时前
Claude Code 源码中 REPL.tsx 深度解析:一个 5005 行 React 组件的架构启示
前端·后端·ai编程
wendycwb7 小时前
前端城市地址根据最后一级倒推,获取各层级id的方法
前端·vue.js·typescript
终端鹿8 小时前
Vue3 模板引用 (ref):操作 DOM 与子组件实例 从入门到精通
前端·javascript·vue.js
千寻girling8 小时前
不知道 Java 全栈 + AI 编程有没有搞头 ?
前端·人工智能·后端
小码哥_常8 小时前
Android开发:精准捕获应用的前后台行踪
前端
蜡台8 小时前
Vue 打包优化
前端·javascript·vue.js·vite·vue-cli
木斯佳9 小时前
前端八股文面经大全:快手前端一面 (2026-03-29)·面经深度解析
前端·宏任务·原型链·闭包