์๋ฌ
Error [ERR_REQUIRE_ESM]: require() of ES Module /app/node_modules/packageA/node_modules/packageB/dist/index.cjs.js from /app/node_modules/packageA/dist/cjs/hooks.js not supported.
index.cjs.js is treated as an ES module file as it is a .js file whose nearest parent package.json contains "type": "module" which declares all .js files in that package scope as ES modules.
Instead either rename index.cjs.js to end in .cjs, change the requiring code to use dynamic import() which is available in all CommonJS modules, or change "type": "module" to "type": "commonjs" in /app/node_modules/packageA/node_modules/packageB/package.json to treat all .js files as CommonJS (using .mjs for all ES modules instead).
์ํฉ
packageA์ hooks.js ํ์ผ์์ packageB๋ฅผ import ํด์ ์ฌ์ฉํ๊ณ ์๊ณ , ์ด ์๋ฌ๋ ๋ณ๋ ์ ์ฅ์์์ packageA ๋ฅผ import ํด์ ์ฌ์ฉํ ๋ ๋ฐ์ํ์์ต๋๋ค. ์๋ฌ๋ฅผ ํด์ํด๋ณด๋ฉด "packageA ๋ด๋ถ์ node_modules์ ์๋ packageB ํ์ผ ์ค index.cjs.js ๋ ES Module ์ด๋ผ require ๋ฌธ์ ์ฌ์ฉํ ์ ์๋ค"๊ณ ํ๋ค.
๋ฌธ์ ํ์ / ํด๊ฒฐ๋ฒ
์ฐ์ .cjs.js ํ์ผ์ด๋ฉด common js ์ธ๋ฐ ์ ์ด ํ์ผ์ ES Module ํ์ผ์ด๋ผ๊ณ ํ๋๊ฑธ๊น?
๋ฐ๋ก packageB๊ฐ type: module ๋ก ์ ์๋์ด ์๊ธฐ ๋๋ฌธ์ด๋ค. type: module ์ package.json ์ ์ ์ํ๋ฉด ํด๋น ํจํค์ง์ ๋ชจ๋ .js ํ์ผ์ esm ์ผ๋ก ์ฒ๋ฆฌ๋๋๋ฐ, cjs ๋ก ๋น๋๋ ํ์ผ์ด๊ธฐ ๋๋ฌธ์ require ๋ฌธ๋ฒ์ด ํ์ผ ์์ ๋ค์ด์๊ณ ์๋ฌ๊ฐ ๋ฐ์ํ๋ ๊ฒ์ด๋ค.
ํด๊ฒฐํ๊ธฐ ์ํด์ node์์ ์ ๊ณตํ ๋ฐฉ๋ฒ์ (์์ ์๋ฌ๋ฌธ์ 2, 3๋ฒ์งธ ์ค) packageB ๋ฅผ ๋น๋ํ ๋ .cjs.js ๊ฐ ์๋ .cjs ํ์ฅ์๋ก ๋น๋ ํ์ผ์ ์ ์ฅํ๋ผ๊ณ ํ๋ค(esm ์ .mjs๋ก). ์ด๋ ๊ฒ ํ๊ฒ ๋๋ฉด default export ์ named export ๊ฐ ํผ๋๋์ด es module interupt ์๋ฌ๊ฐ ๋ฐ์ํ๋ ๊ฒฝ์ฐ๊ฐ ์๋ค.
๋๋ฒ์งธ๋ก๋ type: module ์ ์ ๊ฑฐํ์ฌ ๋์ด์ .js ํ์ผ๋ค์ esm ์ผ๋ก ์ธ์ํ์ง ์๊ฒ ๋ง๋๋ ๋ฐฉ์์ ์ฌ์ฉํ ์ ์๋ค. ์ฐ์ ์ฒซ๋ฒ์งธ ๋ฐฉ์์ ์๋ํด๋ณด๊ณ ์ด์๊ฐ ์๊ธฐ๋ฉด ๋๋ฒ์งธ ๋ฐฉ์์ผ๋ก ํด๊ฒฐํ์.
Comment