>웹 프론트엔드 >프런트엔드 Q&A >nodejs가 뷰 모듈을 찾을 수 없습니다

nodejs가 뷰 모듈을 찾을 수 없습니다

PHPz
PHPz원래의
2023-05-23 14:53:07513검색

최근 Node.js를 사용하여 웹 애플리케이션을 개발하는 동안 다음과 같은 일반적인 오류가 발생했습니다. 보기 모듈을 찾을 수 없습니다. 이 오류는 라우팅 및 보기 폴더 경로를 올바르게 설정했지만 내 앱이 여전히 보기 모듈을 찾을 수 없기 때문에 혼란스럽습니다.

일련의 디버깅과 조사 끝에 이 문제에 대한 몇 가지 해결책을 찾았고 이제 이를 여러분과 공유하겠습니다.

  1. 보기 폴더 경로가 올바르게 설정되지 않았습니다

Express에서 보기 폴더 경로는 일반적으로 ./views로 설정됩니다. 이 폴더의 이름을 변경하거나 다른 위치로 이동하면 보기 모듈을 찾을 수 없는 문제가 발생할 수 있습니다. 이 경우 보기 폴더 경로가 코드에 설정된 경로와 일치하는지 확인해야 합니다.

예를 들어 보기 폴더의 이름을 "ViewFiles"로 바꾸는 경우 app.js 또는 server.js 파일의 보기 폴더 경로를 다음과 같이 설정해야 합니다.

app.set('views', path.join(__dirname, 'ViewFiles'));

여기서 __dirname은 해당 디렉터리가 있는 디렉터리를 나타냅니다. 현재 파일이 위치합니다. 보기 폴더의 경로를 올바르게 설정하지 않으면 Node.js 애플리케이션이 보기 모듈을 찾을 수 없습니다.

  1. View Engine이 올바르게 설치되지 않았습니다.

View Engine은 Node.js 애플리케이션에서 사용하는 템플릿 엔진입니다. 대부분의 Node.js 애플리케이션은 EJS, PUG 또는 Handlebars와 같은 뷰 엔진을 사용합니다. 뷰 엔진을 사용할 때 뷰 모듈을 찾을 수 없는 문제가 발생하는 경우 뷰 엔진이 올바르게 설치되지 않았기 때문일 수 있습니다.

EJS 엔진의 경우 프로젝트에 ejs 종속성을 설치해야 합니다.

npm install ejs --save

그리고 app.js 또는 server.js 파일에 다음 코드를 추가합니다.

app.set('view engine', 'ejs');

PUG 엔진의 경우 프로젝트에 pug 종속성을 설치해야 합니다.

npm install pug --save

다음 코드를 app.js 또는 server.js 파일에 추가하세요.

app.set('view engine', 'pug');

Handlebars 엔진의 경우 프로젝트에 hbs 종속성을 설치해야 합니다.

npm install hbs --save

그리고 app.js 또는 server.js 파일에 다음 코드를 추가하세요. server.js 파일:

app.set('view engine', 'hbs');

뷰 엔진이 설치되어 있고 올바르게 설정되었는지 확인하세요. 그렇지 않으면 Node.js 애플리케이션이 뷰 모듈을 찾을 수 없습니다.

  1. 뷰 파일 이름이 올바르지 않습니다

뷰 파일 이름이 올바르지 않거나 올바른 폴더에 배치되지 않으면 뷰 모듈을 찾지 못할 수 있습니다. 파일 이름이 보기 엔진과 일치하는지 확인하고 해당 파일을 보기 설정 폴더에 배치해야 합니다.

예를 들어 EJS 엔진을 사용하는 경우 파일 이름을 "example.ejs"로 지정하고 설정의 views 폴더에 넣어야 합니다.

그리고 경로에서 다음 코드를 사용하여 뷰를 렌더링합니다.

res.render('example', { title: 'Example' });

위 코드의 "example"은 뷰 파일의 이름을 나타냅니다.

결론:

보기 모듈을 찾을 수 없다는 것은 Node.js 애플리케이션 개발에서 매우 흔한 실수입니다. 이 오류가 발생하면 보기 폴더 경로, 보기 엔진 설정 및 보기 파일 이름이 올바른지 확인하세요. 이러한 설정을 올바르게 지정했지만 여전히 보기 모듈을 찾을 수 없는 경우 코드에서 다른 설정을 확인해야 할 수 있습니다. 이러한 방법은 이 문제를 해결하는 데 도움이 됩니다.

위 내용은 nodejs가 뷰 모듈을 찾을 수 없습니다의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.