解决 Vue 项目中的 reading 'isCE' 报错

Author: Byron Last Updated: 2024-01-17

Cannot read properties of null (reading 'isCE') 解决方案


解决 Vue 项目中的 reading ‘isCE’ 报错

问题场景

构建 Vue 项目时, 如果当前项目的依赖中也有依赖 Vue, 可能会出现如下报错:

Cannot read properties of null (reading 'isCE')

解决方案

名称定义: 消费方: 当前项目 提供方: 当前项目中也同时依赖 Vue 的项目

以下均为基于 Vite 构建工具的配置展示, 并隐藏了其它非相关配置

包管理工具为 pnpm, 供参考

常规步骤

  1. 提供方打包时排除 Vue

vite.config.js

import { defineConfig } from 'vite'

export default defineConfig({
  build: {
    rollupOptions: {
      external: ['vue']
    }
  }
})
  1. 提供方将 Vue 作为 devDependency 而不是 dependency

package.json

{
  "devDependencies": {
    "vue": "^3.2.6"
  }
}

额外步骤

以下步骤为常规步骤无法解决问题时的额外步骤

如, 有时以本地路径方式安装提供方时, 会出现提供方依旧使用提供方自己的 vue, 而不是消费方的 vue; 或其它导致依赖读取不统一的情况

  • 消费方添加 vue 别名指定固定路径

vite.config.js

import { fileURLToPath } from 'node:url'
import { defineConfig } from 'vite'

export default defineConfig({
  resolve: {
    alias: {
      vue: fileURLToPath(new URL('./node_modules/vue', import.meta.url))
    }
  }
})
  • 消费方添加 vue 的重复数据消除

vite.config.js

import { defineConfig } from 'vite'

export default defineConfig({
  resolve: {
    dedupe: ['vue']
  }
})