vue ssr 报错 ReferenceError: MouseEvent is not defined / window is not defined 等等

简介: vue ssr 报错 ReferenceError: MouseEvent is not defined / window is not defined 等等



1. 错误描述

在使用服务端渲染时(基于Vue+vite),将在普通vue项目的组件复制过来,出现了 MouseEvent is not defined 报错,其原文如下:

ReferenceError: MouseEvent is not defined
    at setup (D:/desktop/aaaaaaa/src/components/switchs/Switch.vue:36:12)
    at _sfc_main.setup (/src/components/switchs/Switch.vue:61:23)
    at callWithErrorHandling (D:\desktop\aaaaaaa\node_modules\.pnpm\@vue+runtime-core@3.2.45\node_modules\@vue\runtime-core\dist\runtime-core.cjs.js:157:22)
    at setupStatefulComponent (D:\desktop\aaaaaaa\node_modules\.pnpm\@vue+runtime-core@3.2.45\node_modules\@vue\runtime-core\dist\runtime-core.cjs.js:7176:29)
    at setupComponent (D:\desktop\aaaaaaa\node_modules\.pnpm\@vue+runtime-core@3.2.45\node_modules\@vue\runtime-core\dist\runtime-core.cjs.js:7131:11)
    at renderComponentVNode (D:\desktop\aaaaaaa\node_modules\.pnpm\@vue+server-renderer@3.2.45_vue@3.2.45\node_modules\@vue\server-renderer\dist\server-renderer.cjs.js:172:17)
    at Proxy.ssrRenderComponent (D:\desktop\aaaaaaa\node_modules\.pnpm\@vue+server-renderer@3.2.45_vue@3.2.45\node_modules\@vue\server-renderer\dist\server-renderer.cjs.js:624:12)
    at _sfc_ssrRender (/src/App.vue:91:31)
    at renderComponentSubTree (D:\desktop\aaaaaaa\node_modules\.pnpm\@vue+server-renderer@3.2.45_vue@3.2.45\node_modules\@vue\server-renderer\dist\server-renderer.cjs.js:254:17)
    at renderComponentVNode (D:\desktop\aaaaaaa\node_modules\.pnpm\@vue+server-renderer@3.2.45_vue@3.2.45\node_modules\@vue\server-renderer\dist\server-renderer.cjs.js:188:16)
    at Proxy.renderToString (D:\desktop\aaaaaaa\node_modules\.pnpm\@vue+server-renderer@3.2.45_vue@3.2.45\node_modules\@vue\server-renderer\dist\server-renderer.cjs.js:450:26)
    at render (D:/desktop/aaaaaaa/src/entry-server.ts:12:21)
    at async file:///D:/desktop/aaaaaaa/server.js:54:22

在一个 vue 组件中,有大概如下的代码:

const emit = defineEmits({
  "click": (evt: MouseEvent) => evt instanceof MouseEvent,
})
const slider = ref(null);
const baseColor = useCssVar('--base-color', slider);
// 这里是报错的位置:
const evt = new MouseEvent("click", {
  bubbles: true,
  cancelable: true,
  view: window,
});

其实类似的可能还有这样的报错:window is not defined…。

2. 报错原因

注意这个报错不是 ts 的,因此并不是没有使用 lib:["dom"],如果仅仅是在类型注释中使用了 MouseEvent,是没有问题的。比如:

const emit = defineEmits({
  "click": (evt: MouseEvent) => evt instanceof MouseEvent,
})

原因在于:

在使用 node 服务端进渲染期间 使用浏览器运行时中的的全局对象是不存在的。

3. 解决方案

可以将需要用到的 浏览器 对象 放入 vue 的某些生命周期钩子,让他们处于客户端渲染阶段,如放入 mounted。

例如在 setup 语法下,上面使用到 MouseEvent 的代码可以这样略加修改:

let evt:MouseEvent;
onMounted(()=>{
    evt = new MouseEvent("click", {
    bubbles: true,
    cancelable: true,
    view: window,
  })
})

当然你也可以使用这样的方式将一些浏览器全局对象绑定,不过滥用这些对象又回到了 客户端渲染,需要自己依据情况进行甄别。

目录
相关文章
|
6天前
|
移动开发 JavaScript API
Vue Router 核心原理
Vue Router 是 Vue.js 的官方路由管理器,用于实现单页面应用(SPA)的路由功能。其核心原理包括路由配置、监听浏览器事件和组件渲染等。通过定义路径与组件的映射关系,Vue Router 将用户访问的路径与对应的组件关联,支持哈希和历史模式监听 URL 变化,确保页面导航时正确渲染组件。
|
10天前
|
监控 JavaScript 前端开发
ry-vue-flowable-xg:震撼来袭!这款基于 Vue 和 Flowable 的企业级工程项目管理项目,你绝不能错过
基于 Vue 和 Flowable 的企业级工程项目管理平台,免费开源且高度定制化。它覆盖投标管理、进度控制、财务核算等全流程需求,提供流程设计、部署、监控和任务管理等功能,适用于企业办公、生产制造、金融服务等多个场景,助力企业提升效率与竞争力。
60 12
|
6天前
|
JavaScript 前端开发 开发者
Vue中的class和style绑定
在 Vue 中,class 和 style 绑定是基于数据驱动视图的强大功能。通过 class 绑定,可以动态更新元素的 class 属性,支持对象和数组语法,适用于普通元素和组件。style 绑定则允许以对象或数组形式动态设置内联样式,Vue 会根据数据变化自动更新 DOM。
|
6天前
|
JavaScript 前端开发 数据安全/隐私保护
Vue Router 简介
Vue Router 是 Vue.js 官方的路由管理库,用于构建单页面应用(SPA)。它将不同页面映射到对应组件,支持嵌套路由、路由参数和导航守卫等功能,简化复杂前端应用的开发。主要特性包括路由映射、嵌套路由、路由参数、导航守卫和路由懒加载,提升性能和开发效率。安装命令:`npm install vue-router`。
|
9月前
|
JavaScript API
【vue实战项目】通用管理系统:api封装、404页
【vue实战项目】通用管理系统:api封装、404页
89 3
|
9月前
|
人工智能 JavaScript 前端开发
毕设项目-基于Springboot和Vue实现蛋糕商城系统(三)
毕设项目-基于Springboot和Vue实现蛋糕商城系统
104 0
|
9月前
|
JavaScript Java 关系型数据库
毕设项目-基于Springboot和Vue实现蛋糕商城系统(一)
毕设项目-基于Springboot和Vue实现蛋糕商城系统
220 0
|
9月前
|
JavaScript 前端开发 API
Vue3+Vite+TypeScript常用项目模块详解
现在无论gitee还是github,越来越多的前端开源项目采用Vue3+Vite+TypeScript+Pinia+Elementplus+axios+Sass(css预编译语言等),其中还有各种项目配置比如eslint 校验代码工具配置等等,而我们想要进行前端项目的二次开发,就必须了解会使用这些东西,所以作者写了这篇文章进行简单的介绍。
172 0
Vue3+Vite+TypeScript常用项目模块详解
|
9月前
|
设计模式 JavaScript
探索 Vue Mixin 的世界:如何轻松复用代码并提高项目性能(上)
探索 Vue Mixin 的世界:如何轻松复用代码并提高项目性能(上)
探索 Vue Mixin 的世界:如何轻松复用代码并提高项目性能(上)
|
9月前
|
前端开发 JavaScript Java
毕业设计|基于SpringBoot+Vue的科研课题项目管理系统
毕业设计|基于SpringBoot+Vue的科研课题项目管理系统
224 1

热门文章

最新文章