EJS 템플릿에 데이터 전달 및 그 반대로 전달 — 초보자 가이드
안녕??♂️ ! 이제 막 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에서 오류가 발생하고 앱이 중단될 수 있습니다. 이제 막 시작하는 경우에는 매우 실망스러울 수 있습니다!
하지만 걱정하지 마세요. 간단한 해결 방법이 있습니다. 사용하기 전에 데이터가 존재하는지 확인할 수 있습니다. 다음과 같이 if 조건 안에 데이터를 래핑할 수 있습니다.
<% if (locals.data) { %> <%= data %> <% } else { %>No data available!
<% } %>
이렇게 하면 문제가 발생하거나 데이터가 전달되지 않더라도 앱이 중단되는 일이 발생하지 않습니다. 대신 대체 메시지를 표시하거나 다른 조치를 취할 수 있습니다.
? 프로 팁: 사용하기 전에 항상 템플릿에 데이터가 있는지 확인하세요. 이렇게 하면 많은 어려움을 겪을 필요가 없습니다!
챌린지 타임: EJS에서 서버로 데이터 전달
이 학습 여정을 재미있게 만들기 위해 저는 사용자 이름을 입력으로 사용하고 이름에 몇 글자가 있는지 알려주는 간단한 프로젝트를 만들기로 결정했습니다. 간단하죠? 제가 한 방법은 다음과 같습니다.
입력 데이터 가져오기:
사용자의 성과 이름을 사용하는 HTML 양식을 사용했습니다.서버로 데이터 보내기:
POST를 이용해 입력 데이터를 서버로 보낸 뒤, 이름의 글자수를 계산해봤습니다.처리된 데이터를 템플릿으로 다시 보내기:
페이지에 표시하기 위해 문자 수를 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undress AI Tool
무료로 이미지를 벗다

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

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

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

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

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

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

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

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

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

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