Electron: HTML 페이지의 "require()가 정의되지 않음" 문제 해결
Electron 애플리케이션을 개발할 때 Node.js 기능을 HTML 페이지에서는 "require()가 정의되지 않았습니다."라는 난처한 오류가 발생할 수 있습니다. 이는 Electron의 최신 버전에서 기본 설정이 변경되었기 때문에 발생합니다.
이 문제를 해결하려면 사용자는 브라우저 창을 생성할 때 명시적으로 nodeIntegration을 활성화해야 합니다. 이를 통해 HTML 페이지는 필수 Node.js 모듈과 전역 개체에 액세스할 수 있습니다. 예는 다음과 같습니다.
<code class="javascript">// Enable nodeIntegration and disable contextIsolation in BrowserWindow app.on('ready', () => { mainWindow = new BrowserWindow({ webPreferences: { nodeIntegration: true, contextIsolation: false, } }); });</code>
이 설정을 활성화하면 다음과 같은 변수를 HTML 페이지 내에서 원활하게 사용할 수 있습니다.
<code class="javascript">var app = require('electron').remote; var dialog = app.dialog; var fs = require('fs');</code>
nodeIntegration을 활성화하면 Electron은 다음에 대한 HTML 페이지 액세스 권한을 부여합니다. Node.js 환경을 통해 사용자는 애플리케이션 인터페이스 전반에 걸쳐 Node.js의 기능과 객체를 활용할 수 있습니다.
위 내용은 내 Electron 앱이 HTML 페이지에서 \"require()가 정의되지 않았습니다\" 오류를 발생시키는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!