Nuxt3报错window is not defined解决方法

34 篇文章 1 订阅
29 篇文章 0 订阅

问题

在这里插入图片描述
因为 Nuxt.js 是一个服务器端渲染框架,在服务器端环境中,window 对象不可用。

解决

在nuxt2中解决方法

方式1

在这里插入图片描述
内容:

import { defineNuxtPlugin } from "#app";
import wordCloud from 'vue-wordcloud'
export default defineNuxtPlugin((nuxtApp) => {
    nuxtApp.vueApp.use(wordCloud);
});

注意:后缀名为client.js表示在客户端渲染

方式2

在配置文件中添加

  plugins: [
        {
            src: '~/plugins/word-cloud.js',
            mode: 'client',
        },
    ]

总结

两种方式原理相同,写法不一样。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
回答: 当在Nuxt中使用window对象时,会报错"window is not defined"的错误。这是因为Nuxt是服务器端渲染的框架,编译打包时会区分服务端渲染和客户端渲染。在vue文件中使用window对象会导致报错,因为webpack将其加入了服务端脚本中。为了解决这个问题,可以在使用window对象之前判断当前代码环境是否是浏览器环境。另外,如果在引入工具包时报错,可以将工具包进行拆分,只引入需要的部分。还可以使用no-ssr组件来解决问题,该组件只在客户端呈现,可以避免在服务器渲染时出现window对象未定义的错误。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* *3* [Nuxt.js 报错 window is not defined || document is not defined](https://blog.csdn.net/SR1918/article/details/120880043)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [nodejs.ReferenceError:window is not defined](https://blog.csdn.net/qq_46595660/article/details/125418769)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值