앵귤러, 리엑트, 뷰

'ImportMeta' 형식에 'env' 속성이 없습니다.

마샤와 곰 2023. 12. 12. 11:50

 

타입스크립트(Typescript) 환경에서 env를 import 하는 경우에 발생하는 컴파일 단계에서의 오류 입니다.

가령 아래와 같은 코드를 사용하려 하는데.. 해당 오류를 만나는 경우가 있습니다.

const mode : string = import.meta?.env?.MODE

if(mode ==='development'){
    console.log('개발모드 입니다')
} else {
    console.log('운영모드 입니다')
}

 

타입스크립트가 meta 이하의 env가 무엇인지 몰라 발생하는 오류이므로 해당 오류를 해결하기 위해서는 간단하게 파일 한개만 추가하여주면 됩니다.

* 파일이름 : env.d.ts  (경로는 최상위 src 디렉토리이여 합니다)

//인터페이스를 통한 타입 추론
interface ImportMeta {
  env: {
    MODE: string  //개발모드, 운영모드여부
    SERVER_URL: string  //이런식으로 env 파일에 정의한 내용을 기술~
    HELLO_URL: number   //이런식으로 env 파일에 정의한 내용을 기술~
    WORLD_URL: array    //이런식으로 env 파일에 정의한 내용을 기술~
  }
}

 

물론 env 파일은 따로 존재하여야 합니다.

위와 같이 특정 기능은 없지만 타입을 정의하여주는 파일, d.ts 파일은 기존 JavaScript로 만들어진 모듈들을 TypeScript 환경에서도 사용할 수 있도록 따로 타입만 정리해서 넣어둔 파일이라 할 수 있습니다.

 

 

추가로, 사용중인 모듈(라이브러리)에 확장 기능을 추가한 경우 타입 추론이 안될 수 있습니다.

예를 들어 pinia를 설치하여 사용하는데 pinia-plugin-persistedstate 을 추가로 설치하였다고 가정하여 봅니다.

pinia에서 사용하는 함수인 defineStore를 사용하여 상태를 만들 수 있습니다.

아래는 샘플 코드 입니다.

import { defineStore } from 'pinia'


export const 상태 = defineStore('search', {
  state: () => {
    return {
      list: []
    }
  },
  actions: {

  },
  getters: {}
})

 

 

여기에 로컬스토리지나 세션 스토리지를 사용하고 싶어서 pinia-plugin-persistedstate를 설치하였습니다.

pinia-plugin-persistedstate에서는 defineStore 함수에 persist를 재 정의하여 아래와 같이 사용할 수가 있습니다.

import { defineStore } from 'pinia'


export const 상태 = defineStore('search', {
  persist: {
    storage: localStorage //로컬 저장소 사용
  },
  state: () => {
    return {
      list: []
    }
  },
  actions: {

  },
  getters: {}
})

 

위 코드는 문제없이 동작은하나...

타입스크립트는 pinia의 defineStore에 정의된 타입만 기억하기 때 문에 persist를 추가하면 오류가 발생 합니다.

defineStore의 d.ts 파일에 해당 내용이 없어서 생긴 오류입니다만..이해는 되는데 이걸 어쩔..?ㅠ

 

 

이럴 경우에는 tsconfig.json 파일에 아래처럼 types에 추가한 라이브러리(모듈)을 기록해 주어야 합니다.

* 파일이름 : tsconfig.json

{
  //생략..
  "compilerOptions": {
    //생략..
    "types": ["pinia-plugin-persistedstate"]  //이런식으로 확장된 모듈을 추가
  }
}

 

간단하게 살펴본 타입스크립트 환경에서 env 파일에 대한 내용이였습니다.

틀린부분 또는 다른의견은 언제든지 감사합니다! 😁

반응형