"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > Reactjs에 대한 vite 오류 수정 - 전역이 정의되지 않았고 프로세스가 정의되지 않았습니다.

Reactjs에 대한 vite 오류 수정 - 전역이 정의되지 않았고 프로세스가 정의되지 않았습니다.

2024-11-02에 게시됨
검색:375

Fixing vite error for reactjs - global is not defined and process is not defined

프로젝트에 대한 Reactjs 템플릿을 사용하여 vite 앱을 실행하고 .env 파일에서 환경 변수를 가져오려고 하는 시나리오에서. .env에서 환경 변수를 가져오는 일반적인 방법은 다음과 같이 변수에 대해 process.env.SOMETHING을 사용하는 것입니다.

뭔가=비밀 소스
SOMETHING=SECRETSAUCE
이 시점에서 vite.config.ts는 다음과 같습니다:


'vite'에서 { 정의 구성 } 가져오기 '@vitejs/plugin-react'에서 반응 가져오기 // https://vitejs.dev/config/ 기본 정의 구성 내보내기({ 플러그인: [반응()], })
SOMETHING=SECRETSAUCE
그러나 vite에서는 변수 가져오기가 바로 작동하지 않으며 문제를 해결할 수 있는 방법이 많이 있습니다. 나는 그 중 대부분을 시도했고 간단하고 직접적인 방법을 고수하는 것을 느꼈습니다.

아마도 위의 정의와 process.env.*의 기본 가져오기 논리를 사용하면 Uncaught ReferenceError: global is not Defined 오류가 발생했을 것입니다.

Stackoverflow에서 많은 참조를 찾았는데 혼란스럽습니다.

오류에 대한 수정은 아래와 같이 config에서 global을 정의하는 것입니다.


'vite'에서 { 정의 구성 } 가져오기 '@vitejs/plugin-react'에서 반응 가져오기 // https://vitejs.dev/config/ 기본 정의 구성 내보내기({ 플러그인: [반응()], 정의하다: { 전역: {}, }, })
SOMETHING=SECRETSAUCE
이제 이는 또 다른 일반적인 오류 Uncaught ReferenceError: 프로세스가 정의되지 않음으로 이어질 수 있습니다.

다시 말하지만, 웹에는 많은 솔루션이 있으며 일부는 오래되었습니다. 가장 관련성이 높고 구현하기 쉬운 방법은 vite 라이브러리에서 loadEnv를 가져오고 아래와 같이 사용자 정의 로직을 구축하는 것입니다.


'vite'에서 { 정의 구성, 로드Env } 가져오기 '@vitejs/plugin-react'에서 반응 가져오기 // https://vitejs.dev/config/ 기본 정의 내보내기(({ 모드 }) => { const env = loadEnv(mode, process.cwd(), ''); 반품 { 정의하다: { 전역: {}, 'process.env': 환경 }, 플러그인: [반응()], } })
SOMETHING=SECRETSAUCE
그리고 바로 마법이 일어납니다!!

또한 process.env.*를 사용하여 코드에서 환경 변수 가져오기가 dotenv 없이도 잘 작동하므로 dotenv 종속성을 사용할 필요가 없습니다.

즐거운 코딩하세요!

릴리스 선언문 이 기사는 https://dev.to/rajinh24/fixing-vite-error-for-reactjs-global-is-not-define-and-process-is-not-define-4ffo?1에서 재현됩니다. 침해, 삭제하려면 [email protected]으로 문의하세요.
최신 튜토리얼 더>
  • 아직 9월인가요?
    아직 9월인가요?
    모두 좋은 아침입니다. 월요일 DEV도 행복하세요 찻집 본격적으로 돌아왔습니다. 9월에 PC로 복귀하는 것이 좋은 이유 중 하나는 9월입니다! 초창기부터 뉴스레터를 구독하신 분들, 오픈소스의 세계를 구독해 오신 분들은 이미 아시겠지만, 10월에는 한 달 동안 진행되는 ...
    프로그램 작성 2024-11-02에 게시됨
  • for 루프에서 잘못된 반환 문으로 인해 프로그램이 조기 종료되는 이유는 무엇입니까?
    for 루프에서 잘못된 반환 문으로 인해 프로그램이 조기 종료되는 이유는 무엇입니까?
    for 루프의 잘못된 반환 문이 프로그래밍 문제에서 사용자는 동물 세 마리에 대한 사용자 입력을 허용하는 프로그램을 만드는 데 어려움을 겪습니다. . 이 프로그램은 이름, 동물 유형 및 나이가 포함된 Pet 개체로 목록을 채우도록 설계되었습니다. 그러나 첫 번째 동물을...
    프로그램 작성 2024-11-02에 게시됨
  • 항목 다른 유형이 더 적합한 문자열은 피하세요.
    항목 다른 유형이 더 적합한 문자열은 피하세요.
    1. 다른 데이터 유형의 대체물로 문자열을 사용하지 마십시오: 문자열은 텍스트를 나타내기 위해 설계되었지만 숫자, 열거형 또는 집계 구조를 나타내는 데 오용되는 경우가 많습니다. 데이터가 본질적으로 숫자인 경우 String이 아닌 int, float 또는 BigInt...
    프로그램 작성 2024-11-02에 게시됨
  • sync.WaitGroup을 사용하여 Go 동시성에서 교착 상태를 방지하는 방법은 무엇입니까?
    sync.WaitGroup을 사용하여 Go 동시성에서 교착 상태를 방지하는 방법은 무엇입니까?
    고루틴 교착 상태 해결이 시나리오에서는 Go 동시성 코드에서 교착 상태 오류가 발생했습니다. 문제를 자세히 살펴보고 효율적인 솔루션을 제공하겠습니다.생산자와 소비자의 행동 불일치로 인해 오류가 발생합니다. 생산자 기능에 구현된 생산자는 제한된 기간 동안 채널 ch에 값...
    프로그램 작성 2024-11-02에 게시됨
  • 텍스트 파일에서 유니코드 텍스트를 처리하는 방법: 오류 없는 쓰기를 위한 완벽한 가이드
    텍스트 파일에서 유니코드 텍스트를 처리하는 방법: 오류 없는 쓰기를 위한 완벽한 가이드
    텍스트 파일의 유니코드 텍스트: 오류 없는 쓰기를 위한 종합 가이드Google 문서에서 추출된 데이터를 코딩하는 것은 특히 어려울 수 있습니다. HTML 사용을 위해 변환해야 하는 ASCII가 아닌 기호를 발견할 때. 이 가이드는 유니코드 텍스트를 처리하고 인코딩 오류...
    프로그램 작성 2024-11-02에 게시됨
  • EchoAPI와 불면증: 실제 사례를 통한 종합 비교
    EchoAPI와 불면증: 실제 사례를 통한 종합 비교
    풀 스택 개발자로서 저는 API 디버깅, 테스트, 문서화를 위한 최고의 도구를 보유하는 것이 얼마나 중요한지 알고 있습니다. EchoAPI와 Insomnia는 두 가지 뛰어난 옵션으로 각각 고유한 기능과 기능을 갖추고 있습니다. 이러한 도구를 안내하고, 기능과 이점을 ...
    프로그램 작성 2024-11-02에 게시됨
  • 이동 시간 및 기간 | 프로그래밍 튜토리얼
    이동 시간 및 기간 | 프로그래밍 튜토리얼
    소개 이 랩의 목표는 Go의 시간 및 기간 지원에 대한 이해도를 테스트하는 것입니다. 시간 아래 코드에는 Go에서 시간과 기간을 사용하는 방법에 대한 예가 포함되어 있습니다. 그러나 코드의 일부가 누락되었습니다. 귀하의 임무는 예상대로 작...
    프로그램 작성 2024-11-02에 게시됨
  • 호이스팅 면접 질문 및 답변
    호이스팅 면접 질문 및 답변
    1. 자바스크립트에서 호이스팅이란 무엇인가요? 답변: 호이스팅은 변수와 함수에 메모리가 할당되는 실행 컨텍스트 생성 단계의 프로세스입니다. 이 프로세스 동안 변수에 대한 메모리가 할당되고 변수에는 정의되지 않은 값이 할당됩니다. 함수의 경우 전체 함수 ...
    프로그램 작성 2024-11-02에 게시됨
  • JavaScript의 DOM(문서 개체 모델) 이해
    JavaScript의 DOM(문서 개체 모델) 이해
    안녕하세요, 놀라운 JavaScript 개발자 여러분? 브라우저는 스크립트(특히 JavaScript)가 웹 페이지 레이아웃과 상호 작용할 수 있도록 하는 DOM(문서 개체 모델)이라는 프로그래밍 인터페이스를 제공합니다. 페이지의 구성 요소를 개체로 배열...
    프로그램 작성 2024-11-02에 게시됨
  • SPRING BATCH로 프로그래밍 시작
    SPRING BATCH로 프로그래밍 시작
    Introduction Dans vos projets personnels ou professionnels, Il vous arrive de faire des traitements sur de gros volumes de données. Le traite...
    프로그램 작성 2024-11-02에 게시됨
  • CSS로 Github 프로필을 돋보이게 만드세요
    CSS로 Github 프로필을 돋보이게 만드세요
    이전에는 Github 프로필을 맞춤 설정할 수 있는 유일한 방법은 사진을 업데이트하거나 이름을 변경하는 것이었습니다. 이는 모든 Github 프로필이 동일해 보이고 이를 사용자 정의하거나 눈에 띄게 하는 옵션이 최소화되었음을 의미합니다. 이후부터 Markdown을 사용...
    프로그램 작성 2024-11-02에 게시됨
  • TypeScript 유틸리티 유형: 코드 재사용성 향상
    TypeScript 유틸리티 유형: 코드 재사용성 향상
    TypeScript는 개발자가 유형을 효과적으로 변환하고 재사용할 수 있는 내장 유틸리티 유형을 제공하여 코드를 더욱 유연하고 DRY하게 만듭니다. 이 기사에서는 TypeScript 기술을 다음 단계로 끌어올리는 데 도움이 되는 Partial, Pick, Omit 및 ...
    프로그램 작성 2024-11-02에 게시됨
  • 텔레그램 window.open(url, &#_blank&#); iOS에서는 이상하게 작동합니다
    텔레그램 window.open(url, &#_blank&#); iOS에서는 이상하게 작동합니다
    텔레그램 봇을 만들고 있는데 미니앱의 일부 정보를 채팅으로 전달하는 옵션을 추가하고 싶습니다. 나는 window.open(url, '_blank');를 사용하기로 결정했습니다. iPhone에서 사용해 보기 전까지는 잘 작동했습니다. 전달하는 대신 공유 기...
    프로그램 작성 2024-11-02에 게시됨
  • 프론트엔드 개발자는 누구인가요?
    프론트엔드 개발자는 누구인가요?
    오늘날 인터넷상의 모든 웹사이트나 플랫폼의 사용자 인터페이스 부분은 프런트 엔드 개발자의 작업 결과입니다. 이들은 사용자 친화적인 인터페이스를 만드는 데 참여하여 사이트의 모양과 기능을 보장합니다. 그렇다면 프론트엔드 개발자는 정확히 누구일까요? 간단하게 설명드리겠습니...
    프로그램 작성 2024-11-02에 게시됨
  • 보존된 CSS 스타일을 사용하여 HTML 콘텐츠를 PDF로 저장하는 방법은 무엇입니까?
    보존된 CSS 스타일을 사용하여 HTML 콘텐츠를 PDF로 저장하는 방법은 무엇입니까?
    CSS가 포함된 HTML 콘텐츠를 PDF로 저장웹 개발에서는 콘텐츠를 다른 형식으로 내보낼 때에도 시각적 미학을 유지하는 것이 중요합니다. 변환 프로세스 중에 CSS 스타일이 손실될 수 있으므로 HTML 요소를 PDF로 저장하려고 할 때 문제가 발생할 수 있습니다.저장...
    프로그램 작성 2024-11-02에 게시됨

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3