웹 프론트엔드 JS 튜토리얼 Nuxt 애플리케이션에서 '네비게이터/창/문서가 정의되지 않았습니다' 오류가 발생하는 이유는 무엇입니까?

Nuxt 애플리케이션에서 '네비게이터/창/문서가 정의되지 않았습니다' 오류가 발생하는 이유는 무엇입니까?

Nov 12, 2024 pm 07:00 PM

Why do I get

Nuxt에서 정의되지 않은 오류 탐색: "네비게이터/창/문서가 정의되지 않았습니다" 해결

Nuxt 애플리케이션에서 개발자는 시도할 때 종종 문제에 직면합니다. "네비게이터", "창" 또는 "문서"와 같은 특정 전역 변수에 액세스합니다. 이는 이러한 변수에 의존하는 JavaScript 코드를 실행할 때 발생할 수 있습니다.

이 문제를 해결하려면 Nuxt 애플리케이션이 HTML을 전송하기 전에 서버에서 생성하는 SSR(Server-Side Rendering)을 사용한다는 점을 이해하는 것이 중요합니다. 클라이언트. 전역 변수는 브라우저 환경에서만 사용할 수 있으므로 SSR 중에는 사용할 수 없습니다.

Nuxt 내에서 이러한 전역 변수에 액세스하려면 클라이언트 측 전용 접근 방식을 사용해야 합니다.

클라이언트측 로직을 "if (process.client) { ... }"로 래핑합니다:

래핑 "if (process.client)" 조건의 JS 코드입니다. 이렇게 하면 다음 전역 변수를 사용할 수 있는 클라이언트 측에서만 코드가 실행됩니다.

export default {
  mounted() {
    if (process.client) {
      console.log(navigator.userAgent);
    }
  },
};
로그인 후 복사

"<client-only>"를 사용하세요:

클라이언트 측에서만 렌더링되어야 하는 구성 요소를 다음으로 래핑합니다. "<클라이언트 전용>":

&lt;template&gt;
  &lt;div&gt;
    &lt;p&gt;This will be rendered on both server and client.&lt;/p&gt;
    
    &lt;client-only&gt;
      &lt;p&gt;This will only be rendered on client.&lt;/p&gt;
    &lt;/client-only&gt;
  &lt;/div&gt;
&lt;/template&gt;
로그인 후 복사

SSR용 라이브러리를 동적으로 가져오기:

일부 라이브러리는 SSR을 지원하지 않을 수 있습니다. 이를 사용하려면 동적 가져오기를 사용하여 조건부로 가져옵니다.

export default {
  components: {
    [process.client &amp;amp;&amp;amp; 'MyComponent']: () =&gt; import('./MyComponent.vue'),
  }
};
로그인 후 복사

직접 가져오기:

클라이언트 측에서만 사용하도록 만들어진 구성 요소의 경우 다음과 같이 직접 가져올 수 있습니다.

export default {
  components: {
    'MyComponent': () =&gt; import('./MyComponent.vue'),
  }
};
로그인 후 복사

이러한 접근 방식을 따르면 개발자는 다음과 같은 전역 변수에 성공적으로 액세스하고 조작할 수 있습니다. Nuxt 애플리케이션 내의 "navigator", "window" 및 "document".

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

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

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

JavaScript로 문자열 문자를 교체하십시오 JavaScript로 문자열 문자를 교체하십시오 Mar 11, 2025 am 12:07 AM

JavaScript로 문자열 문자를 교체하십시오

jQuery 날짜가 유효한지 확인하십시오 jQuery 날짜가 유효한지 확인하십시오 Mar 01, 2025 am 08:51 AM

jQuery 날짜가 유효한지 확인하십시오

jQuery는 요소 패딩/마진을 얻습니다 jQuery는 요소 패딩/마진을 얻습니다 Mar 01, 2025 am 08:53 AM

jQuery는 요소 패딩/마진을 얻습니다

상위 5 일 날짜 조작 JS 플러그인 상위 5 일 날짜 조작 JS 플러그인 Feb 28, 2025 am 12:34 AM

상위 5 일 날짜 조작 JS 플러그인

10 JQuery 플러그인을 확인할 가치가 있습니다 10 JQuery 플러그인을 확인할 가치가 있습니다 Mar 01, 2025 am 01:29 AM

10 JQuery 플러그인을 확인할 가치가 있습니다

10 JQuery Accordions 탭 10 JQuery Accordions 탭 Mar 01, 2025 am 01:34 AM

10 JQuery Accordions 탭

jQuery div에 스크롤 바를 추가합니다 jQuery div에 스크롤 바를 추가합니다 Mar 01, 2025 am 01:30 AM

jQuery div에 스크롤 바를 추가합니다

10 Ajax/JQuery Autocomplete 튜토리얼/플러그인 10 Ajax/JQuery Autocomplete 튜토리얼/플러그인 Feb 28, 2025 am 01:03 AM

10 Ajax/JQuery Autocomplete 튜토리얼/플러그인

See all articles