>웹 프론트엔드 >JS 튜토리얼 >Nuxt 애플리케이션에서 네비게이터, 창 및 문서가 정의되지 않은 이유는 무엇입니까?

Nuxt 애플리케이션에서 네비게이터, 창 및 문서가 정의되지 않은 이유는 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-11 20:35:03364검색

Why Are Navigator, Window, and Document Undefined in Nuxt Applications?

Nuxt 애플리케이션에서 정의되지 않은 네비게이터, 창 및 문서를 해결하는 방법

소개

개발자는 Nuxt 애플리케이션 내에서 탐색기, 창 및 문서가 정의되지 않은 상태로 유지되는 오류를 자주 경험합니다. 이 문제는 UserAgent 또는 Retina 정보와 같은 브라우저 관련 정보에 액세스하려고 할 때 발생합니다.

해결 방법

이 문제를 해결하려면 특정 구조 내에 JavaScript 코드를 래핑하여 클라이언트 측에서만 적절한 실행을 보장합니다.

Mounted() Hook 및 process.client로 코드 래핑

<script>
import { jsPlumb } from 'jsplumb'; // client-side library only, no SSR support

export default {
  mounted() {
    if (process.client) {
      // your JS code here like >> jsPlumb.ready(function () {})
    }
  },
}
</script>

클라이언트 전용 구성 요소 활용

<template>
  <div>
    <p>this will be rendered on both: server + client</p>
    
    <client-only>
      <p>this one will only be rendered on client</p>
    </client-only>
  </div>
</template>

지원되지 않는 SSR 패키지 처리

가져오기 시 SSR을 지원하지 않는 라이브러리의 경우 동적 가져오기 또는 직접 로드 사용을 고려하세요.

export default {
  components: {
    [process.client & && 'VueEditor']: () => import('vue2-editor'),
  }
}

추가 팁

  • <클라이언트 전용> 내에서 구성요소 래핑을 피하세요. 렌더링을 방지할 의도가 없다면
  • 동적 가져오기는 애플리케이션에서 나중에 사용되는 라이브러리에 적합합니다.
  • 자세한 지침은 공식 Nuxt 설명서(https://nuxtjs. org/docs/2.x/features/nuxt-comComponents/#the-client-only-comComponent)

위 내용은 Nuxt 애플리케이션에서 네비게이터, 창 및 문서가 정의되지 않은 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.