웹 프론트엔드 JS 튜토리얼 EJS 템플릿에 데이터 전달 및 그 반대로 전달 — 초보자 가이드

EJS 템플릿에 데이터 전달 및 그 반대로 전달 — 초보자 가이드

Sep 14, 2024 pm 02:30 PM

안녕??‍♂️ ! 이제 막 EJS(Embedded JavaScript)를 시작했고 서버EJS 템플릿 간에 데이터를 전달하는 방법이 궁금하다면 잘 찾아오셨습니다 ! 저는 이번 주 내내 EJS에 대해 배우고 있었는데, EJS에 데이터를 전달하는 방법과 데이터 작업 방법에 대해 제가 배운 내용을 공유하고 싶었습니다.


서버에서 EJS 템플릿으로 데이터를 전달하는 방법

따라서 서버(Node.js Express)에서 EJS 템플릿으로 데이터를 전송하려는 경우 매우 간단합니다. res.render() 메소드를 사용하면 서버에서 .ejs 파일로 데이터를 보낼 수 있습니다.

방법은 다음과 같습니다.

res.render("ejs_file_name", { data });

이 예에서는 EJS 파일(index.ejs라고 가정)을 렌더링하고 데이터 개체를 템플릿에 전달합니다.

그런 다음 EJS 템플릿에서 이 데이터를 사용하려면 다음과 같이 액세스하면 됩니다.

<%= data %>

간단한 분석은 다음과 같습니다.

  • res.render()는 데이터를 템플릿으로 보내는 역할을 담당합니다.
  • EJS의 <%= data %> 태그에는 전달된 데이터가 표시됩니다.

데이터 이름(이 경우 데이터와 같은)이 두 위치(서버 코드와 EJS 템플릿)에서 동일한지만 확인하세요. 일치하지 않으면 상황이 이상해집니다!


잠깐… 데이터가 없으면 어떻게 되나요? ?

여기에 까다로운 부분이 있습니다. EJS는 사용하기 전에 데이터가 존재하는지 확인하지 않습니다. 데이터가 항상 존재하는 것처럼 사용합니다. 따라서 존재하지 않는(또는 제대로 전달되지 않은) 일부 데이터에 액세스하려고 하면 EJS에서 오류가 발생하고 앱이 중단될 수 있습니다. 이제 막 시작하는 경우에는 매우 실망스러울 수 있습니다!

Passing Data to EJS Templates and Vice-Versa — A Beginner

하지만 걱정하지 마세요. 간단한 해결 방법이 있습니다. 사용하기 전에 데이터가 존재하는지 확인할 수 있습니다. 다음과 같이 if 조건 안에 데이터를 래핑할 수 있습니다.

<% if (locals.data) { %>
  <%= data %>
<% } else { %>
  

No data available!

<% } %>

이렇게 하면 문제가 발생하거나 데이터가 전달되지 않더라도 앱이 중단되는 일이 발생하지 않습니다. 대신 대체 메시지를 표시하거나 다른 조치를 취할 수 있습니다.

? 프로 팁: 사용하기 전에 항상 템플릿에 데이터가 있는지 확인하세요. 이렇게 하면 많은 어려움을 겪을 필요가 없습니다!


챌린지 타임: EJS에서 서버로 데이터 전달

이 학습 여정을 재미있게 만들기 위해 저는 사용자 이름을 입력으로 사용하고 이름에 몇 글자가 있는지 알려주는 간단한 프로젝트를 만들기로 결정했습니다. 간단하죠? 제가 한 방법은 다음과 같습니다.

  1. 입력 데이터 가져오기:
    사용자의 성과 이름을 사용하는 HTML 양식을 사용했습니다.

  2. 서버로 데이터 보내기:
    POST를 이용해 입력 데이터를 서버로 보낸 뒤, 이름의 글자수를 계산해봤습니다.

  3. 처리된 데이터를 템플릿으로 다시 보내기:
    페이지에 표시하기 위해 문자 수를 EJS 템플릿에 다시 전달했습니다.

이를 처리하는 서버측 코드는 다음과 같습니다.

app.post("/submit", (req, res) => {
  const charCnt = req.body["fName"].length + req.body["lName"].length;
  res.render("index.ejs", { charectercount: charCnt });
}); // I used body-parser to get the data from the form
  • req.body는 사용자 입력에서 양식 데이터를 가져옵니다.
  • 이름과 성의 문자 수를 세어 그 수를 EJS 파일에 전달했습니다.
  • 그러면 EJS 템플릿에 문자 수가 표시됩니다.

여기에서 내 GitHub의 프로젝트 코드에서 전체 코드를 확인하세요


간단히 말하면 ?

EJS 템플릿에 데이터를 전달하고 클라이언트에서 데이터를 다시 가져오는 방법에 대한 간략한 요약입니다! EJS는 매우 유연하여 HTML과 JavaScript를 쉽게 혼합할 수 있으며 데이터 전달을 효과적으로 관리하는 방법을 배우면 프로젝트에 많은 가능성이 열립니다.

이 게시물의 주요 내용은 다음과 같습니다.

  • res.render()를 사용하여 서버의 데이터를 EJS 템플릿으로 전달하세요.
  • 충돌을 방지하려면 템플릿에서 사용하기 전에 항상 데이터가 존재하는지 확인하세요.
  • req.body(POST 요청의 경우)를 사용하여 쉽게 데이터를 서버로 다시 보내고 처리할 수 있습니다.

저처럼 배우는 중이라면 이 게시물이 상황을 더 명확하게 하고 초기 함정을 피하는 데 도움이 되기를 바랍니다. 아래에 질문이나 의견을 남겨주세요! ?

위 내용은 EJS 템플릿에 데이터 전달 및 그 반대로 전달 — 초보자 가이드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Stock Market GPT

Stock Market GPT

더 현명한 결정을 위한 AI 기반 투자 연구

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

JavaScript에서 데이터 속성으로 요소를 어떻게 선택합니까? JavaScript에서 데이터 속성으로 요소를 어떻게 선택합니까? Aug 30, 2025 am 01:57 AM

CSS 속성 선택기를 통해 JavaScript의 데이터 속성을 사용하여 요소를 선택하고 문서를 사용하여 문서를 사용하여이를 달성하십시오. 1. [data-attribute]를 사용하여 지정된 데이터 속성 (모든 값)이있는 요소를 선택하십시오. 2. [data-attribute = "value"]를 사용하여 속성 값이 정확히 일치하는 요소를 선택하십시오. 3. Data-User-ID가 DataSet.userId에 해당하는 Element.Dataset을 통해 데이터 속성에 액세스하십시오.

Pytest 및 Selenium : 동적 데이터 중심 테스트를위한 구현 전략 Pytest 및 Selenium : 동적 데이터 중심 테스트를위한 구현 전략 Aug 30, 2025 am 06:00 AM

이 기사는 동적 데이터 중심 테스트를 위해 pytest 및 selenium을 사용할 때 런타임에 생성 된 데이터를 직접 처리 할 수없는 @pytest.mark.mark.martrize 데코레이터가 직접 처리 할 수없는 문제를 해결하는 것을 목표로합니다. 우리는 pytest.mark.marketrize의 한계를 탐구하고 Pytest의 pytest_generate_tests 후크 기능을 통해 Selenium 동적 데이터 수집을 기반으로 매개 변수화 된 테스트를 우아하게 구현하는 방법을 자세히 소개하여 테스트 사례의 유연성과 효율성을 보장합니다.

근무일 및 근무 시간으로 실행하는 JavaScript 카운터 구축 근무일 및 근무 시간으로 실행하는 JavaScript 카운터 구축 Aug 31, 2025 am 06:30 AM

이 기사는 JavaScript를 사용하여 정확한 타이밍 카운터를 구축하는 방법에 대해 자세히 설명합니다. 카운터는 분에 한 번 증가하지만 사전 설정 근무일 (월요일 ~ 금요일)과 근무 시간 (예 : 오전 6시에서 오후 8시) 이내에 만 운행됩니다. 작동하지 않는 시간에는 증가를 일시 중지 할 수 있지만 현재 값을 표시하고 매월 첫날에 자동으로 재설정하여 계산 로직의 정확성과 유연성을 보장합니다.

jQuery 팝업 창에서 동적 외부 링크 점프의 이벤트 처리 최적화 jQuery 팝업 창에서 동적 외부 링크 점프의 이벤트 처리 최적화 Sep 01, 2025 am 11:48 AM

이 기사는 JQuery 팝업 창에서 외부 링크 리디렉션 버튼을 리디렉션하는 문제를 해결하는 것을 목표로합니다. 사용자가 여러 외부 링크를 연속적으로 클릭하면 팝업의 점프 버튼이 항상 첫 번째 클릭 링크를 가리킬 수 있습니다. 핵심 솔루션은 OFF ( 'Click') 메소드를 사용하여 새 이벤트의 각 바인딩 전에 이전 이벤트 핸들러를 취소하여 점프 동작이 항상 최신 대상 URL을 가리키므로 정확하고 제어 가능한 링크 리디렉션을 달성하는 것입니다.

JavaScript는 클릭 스루 이미지 전환 효과 : 전문 자습서를 인식합니다 JavaScript는 클릭 스루 이미지 전환 효과 : 전문 자습서를 인식합니다 Sep 18, 2025 pm 01:03 PM

이 기사는 JavaScript를 사용하여 이미지를 클릭하는 효과를 얻는 방법을 소개합니다. 핵심 아이디어는 HTML5의 데이터-* 속성을 사용하여 대체 이미지 경로를 저장하고 JavaScript를 통해 클릭 이벤트를 듣고 SRC 속성을 동적으로 전환하여 이미지 전환을 실현하는 것입니다. 이 기사는 일반적으로 사용되는 대화식 효과를 이해하고 마스터하는 데 도움이되는 자세한 코드 예제 및 설명을 제공합니다.

사전로드 스크립트에서 동적으로 생성 된 DOM 요소에 액세스하고 작동하는 방법 사전로드 스크립트에서 동적으로 생성 된 DOM 요소에 액세스하고 작동하는 방법 Aug 30, 2025 am 11:57 AM

이 기사에서는 JavaScript 스크립트가 웹 개발에서 DOM 요소를 생성하기 전에로드 및 실행될 때 JavaScript 스크립트에 효과적으로 액세스하고 조작 할 수있는 방법을 살펴 봅니다. 우리는 세 가지 핵심 전략을 소개합니다. 기능 반환 값을 통해 요소 참조를 직접 통과시키고, 모듈 간 통신을 달성하기 위해 사용자 정의 이벤트를 사용하고, 돌연변이 관상 서버를 사용하여 DOM 구조 변경을 듣습니다. 이러한 방법을 사용하면 개발자가 JavaScript 실행 타이밍과 동적 컨텐츠로드 사이의 과제를 해결할 수 있도록하여 스크립트가 드래그 가능하게 만드는 등 후속 추가 요소를 올바르게 작동시킬 수 있습니다.

JavaScript에서 객체 속성을 업데이트하는 방법 JavaScript에서 객체 속성을 업데이트하는 방법 Sep 04, 2025 am 04:58 AM

알려진 이름;

JavaScript의 진화 : ES2023 이상의 모습 JavaScript의 진화 : ES2023 이상의 모습 Aug 29, 2025 am 12:18 AM

ES2023은 JavaScript의 성숙한 진화를 나타내는 여러 가지 실용적인 업데이트를 도입했습니다. 1.array.prototype.findlast () 및 FindlastIndex () 메소드는 배열 끝에서 검색을 지원하여 로그 처리 효율성 또는 구성의 효율성을 향상시킵니다. 2. Hashbang Syntax (#!/usr/bin/envnode)는 JavaScript 파일을 UNIX와 같은 시스템에서 직접 실행할 수 있습니다. 3.Error.cause는 오류 체인을 지원하여 예외 디버깅 기능을 향상시킵니다. 4. 약점 및 세트의 사양은 교차 엔진 일관성을 향상시킨다. 앞으로 데코레이터 (단계 3), 레코드 및 튜플 (

See all articles