🫢 Damn~~❗️ ReferenceError: window is not defined?

Damn❗️Damn❗️Damn❗️Damn❗️Damn❗️

ReferenceError: window is not defined?

在用 next 开发时是否经常遇到 XXX is not defined !!

🙋‍♀️🌰:在使用ahooks时,依赖windowdocumentnode不支持的对象 那么恭喜你,你应该会看到如下报错

解决方案

jsx 复制代码
'use client'
import { useEffect } from 'react';  
const Page = () => {  
    useEffect(() => {  
        console.log(window.location.origin);  
    }, []);  

    return (  
        <div>  
            <h1>Index Page</h1>  
        </div>  
    );  
}; 
export default Page;

建议封装成hooks

jsx 复制代码
'use client';
import { useRef, useEffect } from 'react';

const useWindow = () => {
    const windowRef = useRef(null);
    useEffect(() => {
        windowRef.current = window;
        // documentRef.current = window.document;
    }, []);
    return windowRef;
};

export default useWindow;

使用

jsx 复制代码
'use client';
import React from 'react';
import { useScroll } from 'ahooks';
import { useDocument } from '@/hooks';

const ScrollTop = () => {
    const document = useDocument();
    const scroll = useScroll(document);
    return (
        ...
        )
    );
};

export default ScrollTop;

扩展

最近在掘金看见了一个下雪特效,我想这tM不拿到我的网站来试试水!

github-snow-fall 科学

演示网站-snow-fall 科学

我看了源码是使用webComponent实现的 so easy!!

PS:想要学习webComponent可以查看源码对照学习

我直接一手import,反手给我一个报错!!

Damn❗️❗️❗️

报错如下

csharp 复制代码
HTMLElement is not defined

部分源码如下:

折腾了一段时间也没搜索到教程

最后解决办法如下:有更好的办法可以在评论区留言

js 复制代码
import dynamic from 'next/dynamic';
dynamic(import('@zachleat/snow-fall'), {
    ssr: false
});
const Snow = () => {
    return (
        <snow-fall></snow-fall>
    );
};

结语

next项目虽然有时在dev环境可以跑通,但build时出现了上述问题是不能编译通过的!!

头图片是蛇皮饼小干

相关推荐
Mike_jia1 分钟前
MeterSphere:开源持续测试平台,让测试管理变得如此简单
前端
Csvn3 分钟前
Vue 3 响应式原理深度解析
前端
恋猫de小郭5 分钟前
Flutter 3.44 发布前夕,官方宣布 SwiftPM 将完全取代 CocoaPods
android·前端·flutter
Json____6 分钟前
vue3-商城管理系统-前端静态网站
前端·vue3·ts·商城纯静态
古怪今人7 分钟前
后台服务开发、前端/手机端开发、服务器部署的版本及框架的终极推荐【2026年】
前端
lightqjx10 分钟前
【前端】前端学习三之初识JavaScript
前端·javascript·学习
IT_陈寒13 分钟前
JavaScript的this又背刺我,这次真长记性了
前端·人工智能·后端
adminwolf13 分钟前
美团点评客服自动回复神器|告别手动回复,轻松达标平台考核
大数据·前端·人工智能
晓得迷路了26 分钟前
栗子前端技术周刊第 127 期 - pnpm 11.0、Remix 3 Beta Preview、Astro 6.20...
前端·javascript·css
Carson带你学Android1 小时前
别再乱学了!深度解读 Google 官方发布 Android 6 大核心 Skills
android·前端·ai编程