์ค๋ฅ
๋ค์๊ณผ ๊ฐ์ ์ค๋ฅ๋ค์ด ๋จ๋ฉด์(๊ฒฝ๊ณ ์ฐฝ) electron ์ฑ์ด ์คํ๋์ง ์์.
(node:29788) Warning: To load an ES module, set "type": "module" in the package.json or use the .mjs extension.
(Use `electron --trace-warnings ...` to show where the warning was created)
App threw an error during load
D:\\2023\\march\\realPractice\\login\\public\\electron.js:1
import * as operator from './script/operator.js'
^^^^^^
SyntaxError: Cannot use import statement outside a module
at Object.compileFunction (node:vm:360:18)
at wrapSafe (node:internal/modules/cjs/loader:1062:15)
at Module._compile (node:internal/modules/cjs/loader:1097:27)
at Module._extensions..js (node:internal/modules/cjs/loader:1196:10)
at Module.load (node:internal/modules/cjs/loader:1011:32)
at Module._load (node:internal/modules/cjs/loader:846:12)
at f._load (node:electron/js2c/asar_bundle:2:13328)
at loadApplicationPackage (D:\\2023\\march\\realPractice\\login\\node_modules\\electron\\dist\\resources\\default_app.asar\\main.js:121:16)
at Object.<anonymous> (D:\\2023\\march\\realPractice\\login\\node_modules\\electron\\dist\\resources\\default_app.asar\\main.js:233:9)
at Module._compile (node:internal/modules/cjs/loader:1141:14)
[25444:0411/155342.712:ERROR:gpu_init.cc(523)] Passthrough is not supported, GL is disabled, ANGLE is
๋ฌธ์ ์์ธ
electron์ CommonJS ๋ฐฉ์์ธ require๋ก ์ฐ๊ณ ์๋๋ฐ, ๊ทธ ์์ ESM๋ฐฉ์์ธ import๋ฌธ์ ์ฌ์ฉํ๊ณ ์์๊ธฐ ๋๋ฌธ.
์ ์ด๋ฐ ํ์์ด ๋ํ๋ ๊น?
React์ Electron์ ํจ๊ป ์ฌ์ฉํ ๋๋ ๋ ๊ฐ์ ํ๋ก์ ํธ์์ ๋ชจ๋ ์์คํ ์ ์ฌ์ฉํ๋ ๋ฐฉ์์ด ์๋ก ๋ค๋ฅด๊ธฐ ๋๋ฌธ์, ๋ชจ๋ ์์คํ ์ ๋ง์ถฐ์ฃผ๋ ์์ ์ด ํ์.
React ์ฑ์์๋ import/export๋ฅผ ์ฌ์ฉํ๊ณ , Electron์์๋ require/module.exports ๋ฅผ ์ฌ์ฉ.
๋ฐ๋ผ์ ๋ ๋ชจ๋ ์์คํ ์ ๋ชจ๋ ์ฌ์ฉํ ์ ์๋ CommonJS ๋ฐฉ์์ ์ฌ์ฉํ๋ ๊ฒ์ ์ถ์ฒ.
ํด๊ฒฐ ๊ณผ์
๋จผ์ terminal ์์ ์ ์ํ ๋ฐฉ๋ฒ ๋๊ฐ์ง๋ฅผ ์ฌ์ฉํด๋ณด์๋ค.
- package.json ํ์ผ์ root์ ๋ค์์ ์ถ๊ฐํ๋ ๋ฐฉ๋ฒ.
{ "type":"module", }
- ⇒ module๋ก ์ ์ํด๋ ์ด๋ฏธ ํ์ผ์์ require์ ์ฌ์ฉํ๊ณ ์๊ธฐ ๋๋ฌธ์ ๊ฐ์ ์ค๋ฅ๊ฐ ๋ฐ์.
- .js ํ์์ .mjs ํ์์ผ๋ก ๋ณํํด module ์ ์
- ⇒์ฌ์ ํ require ์ ์ฌ์ฉํ๊ธฐ ๋๋ฌธ์ ๊ฐ์ ์ค๋ฅ๊ฐ ๋ฐ์
- require ๋ฌธ์ import๋ก ๋ณํ
- ⇒ node ์์ ์ฌ์ฉํ๋ ๋ชจ๋๋ค์ด require๋ก ๋ถ๋ฌ์์ผ ํ๋ ๊ฒ๋ค์ด ์์
ํด๊ฒฐ ๋ฐฉ๋ฒ
๊ฒฐ๊ตญ electron ์ฝ๋์ ์ ์๋ ๋ชจ๋ import ์ require ๋ก ๋ณ๊ฒฝ.
๋ํ exportํ๋ ํจ์๋ค๋ module.exports ๋ก ๋ณ๊ฒฝ.
๊ทธ๋ฌ๋ electron์ฑ์ ์คํ๋์์ง๋ง ํ๋ฉด์ด ๋๋๋ง ๋์ง ์๋ ๋ฌธ์ ๋ฐ์.
'Development > Electron' ์นดํ ๊ณ ๋ฆฌ์ ๋ค๋ฅธ ๊ธ
[Electron] electron์ฑ ํ๋ฉด์ด ๋๋๋ง์ด ๋์ง ์๋ ๋ฌธ์ (0) | 2023.06.18 |
---|---|
[Electron] ipcRenderer.invoke & ipcMin.handle (0) | 2023.06.15 |
[Electron] dialog.showOpenDialog() (0) | 2023.06.15 |
[Electron] electron ์์ด์ฝ ๋ฃ๊ธฐ (0) | 2023.01.25 |
[Electron] Electron + React ์ฐ๋ํ๊ธฐ (0) | 2023.01.13 |
๋๊ธ