// project 폴더 생성
mkdir yarn-berry-workspace
cd yarn-berry-workspace
// yarn 버전 확인
yarn -v
// yarn 버전 변경
yarn set version berry
yarn set version stable
// yarn 버전 확인
yarn -v
// packages 디렉토리 만들기 / 루트 초기화
yarn init -w
./package.json
apps/*
폴더추가
{
"name": "yarn-berry-workspace-test",
"packageManager": "[email protected]",
"private": true,
"workspaces": [
"apps/*",
"packages/*"
]
}
// 1. create-next-app 프로젝트 생성
cd apps
yarn create next-app
저는 아래와 같이 셋팅 하였습니다.
pacakge.json 수정
name @wanted/web
으로 변경
// 3. root가서 상태 갱신하기
cd ..
yarn
// 4. 실행 확인
yarn workspace @wanted/web run dev
./apps/wanted/pages/index.tsx
을 열어보면 typescript error가 발생합니다.
yarn berry는 npm과 모듈을 불러오는 방식이 다르기 때문에 생기는 문제입니다.
yarn add -D typescript
yarn dlx @yarnpkg/sdks vscode
이미 추가 되어 있다면 skip 합니다.
{
"recommendations": ["arcanis.vscode-zipfs"]
}
packages/lib
폴더 생성하고, 아래 스크립트를 실행한다.
// lib 폴더 이동
cd packages/lib
// pacakge.json 파일 생성
yarn init
아래와 같이packages/lib/package.json
파일 수정한다.
{
"name": "@wanted/lib",
"version": "1.0.0",
"private": true,
"main": "./src/index.ts",
"dependencies": {
"typescript": "^4.9.3"
}
}
packages/lib/tsconfig.json
파일 생성 후 설정값 넣기
{
"$schema": "https://json.schemastore.org/tsconfig",
"compilerOptions": {
"strict": true,
"useUnknownInCatchVariables": true,
"allowJs": true,
"skipLibCheck": true,
"forceConsistentCasingInFileNames": true,
"isolatedModules": true,
"newLine": "lf",
"module": "ESNext",
"moduleResolution": "node",
"target": "ESNext",
"lib": ["ESNext", "dom"],
"esModuleInterop": true,
"allowSyntheticDefaultImports": true,
"baseUrl": "./src",
"noEmit": false,
"incremental": true,
"resolveJsonModule": true,
"paths": {}
},
"exclude": ["**/node_modules", "**/.*/", "./dist", "./coverage"],
"include": ["**/*.ts", "**/*.js", "**/.cjs", "**/*.mjs", "**/*.json"]
}
packages/lib/src/index.ts
파일 생성하기 하고 간단한 코드 넣는다.
export const sayHello = () => {
console.log("hello from lib");
return "hello from lib";
};
apps/wanted
에 의존성 주입
// root로 이동한다.
cd ../../
// root 실행한다.
yarn workspace @wanted/web add @wanted/lib
apps/wanted/package.json
에 의존성이 추가된 것을 확인 합니다.
@wanted/lib
에 sayHello
함수를 호출해 봅니다.
그리고, @wanted/web을 구동해 봅니다.
yarn workspace @wanted/web run dev
아래와 같이 hello from lib
이 노출된다면 성공 입니다.