NUXT3项目二开开启SSR后报错localStorege(window) is not defined解决方案

写项目的时候要求在二开项目上开启ssr,配置开启后一直报错window(localStorege、document) is not defined ,多方搜索有人说:在mounted生命周期中用localStorage就可以了,但是主体没有解决,大部分是操作dom的问题。

由于 nextjs 是服务端渲染,它会预渲染页面后生成 HTML,然后再将其发送给客户端,因此在渲染时无法识别 window/document 浏览器的对象方法。

尝试最简单的方案是用if (process.client) {}包起来即可。

if (process.client) {
    const windowWidth = ref(window.innerWidth)
    if (windowWidth.value >= 1200) {
      return '530px'
    } else if (windowWidth.value >= 1024 && windowWidth.value < 1200) {
      return '460px'
    }
}

if (process.client): 这段代码检查当前环境是否为客户端(即在浏览器中)。就比如问题中访问 window 对)只能在客户端运行。

Window Form 应用程序是基于 Windows 操作系统 GUI 界面的应用程序,它使用了多线程技术。在 Window Form 应用程序中,主线程通常用于处理用户界面(UI)操作,而其他线程则用于执行后台任务,例如进行网络通信、文件处理等。这种方式可以避免长时间的操作阻塞 UI 线程,让应用程序更加流畅。 在 Window Form 应用程序中,创建线程的方式与标准的 C# 程序一样,可以使用 Thread 类或 ThreadPool 类来创建线程。但需要注意的是,在 UI 线程中访问 UI 控件是不安全的,必须使用 Invoke 或 BeginInvoke 方法来让 UI 线程更新 UI 控件。 例如,以下代码演示了如何在 Window Form 应用程序中创建一个后台线程来执行耗时的任务: ``` private void btnStart_Click(object sender, EventArgs e) { // 创建后台线程 Thread thread = new Thread(new ThreadStart(DoWork)); thread.Start(); } private void DoWork() { // 执行耗时的任务 // ... // 更新 UI 控件(需要使用 Invoke 或 BeginInvoke 方法) this.Invoke(new Action(() => { // 更新 UI 控件 // ... })); } ``` 在上述代码中,btnStart_Click 方法是 UI 线程中的事件处理程序,当用户点击按钮时会创建一个后台线程来执行任务。DoWork 方法是后台线程的入口点,它执行耗时的任务,并使用 Invoke 方法来更新 UI 控件。这样可以保证 UI 线程不会被阻塞,同时也可以让用户获得更好的体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值