Cohorts
  • Discover
  • About Us
  • Blog
  • Patika.dev
  • Web3

Node.js

Node.js Nedir?
Çalışma Ortamının Kurulması
Asal Sayılar Çalışması
Node.js REPL Ortamı
Ödev 1 - Node.JS Komut Satırı Kullanımı

Node.js'in Asenkron Yapısı
Callback Nedir?
Promise Nedir?
Async - Await Yapısı
Ödev 2 - Post Sıralama ve Post Ekleme

Olay Odaklı - Bloklamayan
Modül Kavramı
Ödev 3 - Daire Modülü
FS Modülü Kullanımı
Ödev 4 - FS Modülü Çalışması
NPM ve Package.json Kavramları
Request - Response Döngüsü
Bir Web Sunucusu Yazmak
Ödev 5 - Kendi Web Sunucumuz
Express.js Giriş
Ödev 6 - Koa.js ile Web Sunucusu Yazımı

PCAT Proje Tanıtımı
PCAT Projesi Çalışma Ortamı
PCAT Projesi Express Nodemon Kurulumu
Clean Blog Proje - 1. Bölüm - Ödev 7
Statik Dosyalar - Middleware Giriş
Template Engine Kavramı
Clean Blog Proje - 2. Bölüm - Ödev 8
MongoDB Giriş
MongoDB - Compass Kurulumu
Mingo Kurulumu
MongoDB - CRUD İşlemleri
Mongoose CRUD İşlemleri
Request Body Nesnesi
Model ve Dinamik İçerik
Clean Blog Proje - 3. Bölüm - Ödev 9
Tekil Fotoğraf Sayfaları
Clean Blog Proje - 4. Bölüm - Ödev 10
Görsel Yüklemek
Fotoğraf Bilgisi Güncellemek
Fotoğraf Silmek
MVC Yeniden Düzenleme
Clean Blog Proje - 5. Bölüm - Ödev 11
PCAT Sayfalama
Heroku - MongoDB Atlas Deployment
Clean Blog Proje - 6. Bölüm - Ödev 12

Smartedu Projesi Tanıtım
HTTP Durum Kodları
Linkleri Güncellemek
Routing - Yönlendirme
Kurs Modeli
Postman ve API
Kursları Listelemek
Tekil Kurs Sayfası ve Slugify
Kategori Oluşturmak ve Listelemek
Kayıt Sayfası ve Bcrypt Paketi
Giriş Sayfası ve Giriş İşlemi
Session Nedir?
Çıkış İşlemi
Kişiye Özel İçerik
Özel Middleware
Kullanıcı Rolleri
Kurs Oluşturmak
Kurs - Öğretmen İlişkisi
Kurs - Öğrenci İlişkisi
Kurs - Öğrenci İlişkisi II
Search Alanı
İletişim Sayfası ve Mail Göndermek
Bildirim Mesajları
Kayıt ve Kullanıcı Doğrulama
Kurs Silmek
Kurs Güncellemek
Admin Alanı ve Kullanıcı Silmek
Kategori Eklemek ve Silmek
Smartedu Deployment

Template Engine Kavramı


Statik dosyalarımızı kullanmaya başladık ve bir önceki çalışmamızda index.html sayfasına ulaştık. Sayfa içeriğini de görebiliyoruz ancak burada şöyle bir sorunumuz var buradaki içeriklerimiz statik yani değişmez içerikler ancak biz sayfamızın dinamik bir şekilde çalışmasını yani içeriğinde değişiklikler yapmayı isteriz. İşte burada template engine -şablon motoru- kavramı devreye girer.


Template Engine Nedir?


Yukarıda belirtiğimiz gibi dinamik olan değişen bir içeriği sabit .html sayfasında gösteremeyiz. Template engine bize bu değişen içeriğin html kodu içerisinde dosya uzantısı değiştirilerek kullanmamızı sağlar. Template engineler sayesinde bir static dosyaları ve değieşn dinamik içeriği birlikte kullanabiliriz. Farklı template engineler kullanılabiliriz, biz bu çalışmamızda EJS template engine yapısını kullanacağız.


EJS Template Engine


EJS, Embedded Java Script kelimelerinden oluşur ve bize saf Javascript kodlarıkullanmamıza imkan verirken aynı zamanda çalışmamıza ait değişen içerikleri de kullanabiliriz.


npm i ejs


komutuyla ejs modülünü indirebiliriz. Ejs modülünü çağıralım ve uygulamamıza template engine olarak "ejs" kullanacağımızı belirtelim.


const ejs = require('ejs');
-----
//Template Engine
app.set("view engine", "ejs");


EJS modülü template dosyaları görebilmek için varsayılan olarak views klasörünün içerisindeki .ejs uzantılı dosyalara bakar. Bu ne denle temp dosyamızın ismini views olarak değiştiriyoruz. Videws klasörü içerisindeki tüm .html uzantılarını .ejs olarak değiştiriyoruz. Uygulamamızdaki .get metodunu düzenlersek, bu şekilde '/' isteğine karşılık index.ejs dosyasını render ederiz.


app.get("/", (req, res) => {
  res.render('index');
});


http://localhost:3000/ adresine tarayıcımızdan istek gönderdiğimizde index sayfamızı başarılı bir şekilde görebileceğiz. Yalnız burada tüm .ejs dosyalarını incelediğimizde bazı ortak bölümlerin bulunduğunu görebiliriz. Bu ortak alanları views/partials klasörünün içerisine yerleştireceğiz. Burada yapmamız gereken _header.ejs, _footer.ejs, _navigation.ejs dosyalarını oluşturarak ortak kod bölümlerini buraya yapıştıralım. index template dosyasının yanında diğer template dosyalarımızı da düzenleyelim. About ve Add New Post sayfaları için gerekli yönlendirmeleri yapalım.


----
app.get("/about", (req, res) => {
  res.render('about');
});

app.get("/add_post", (req, res) => {
  res.render('add_post');
});


sonra _navigation.ejs de linkleri güncelleyelim.


 <li class="nav-item">
  <a class="nav-link" href="/">Home</a>
</li>
<li class="nav-item">
  <a class="nav-link" href="/about">About</a>
</li>
<li class="nav-item">
  <a class="nav-link" href="/add_post">Add New Post</a>
</li>

son olarak add.ejs syafamızı video içeriğimize göre güncelleyelim.

Quiz

Answer the questions to check your understanding.

This lesson includes a short quiz.

Previous
Next

Lesson discussion

Swap insights and ask questions about “Node.js”.

Enroll to participate
Start the course to unlock the discussion. Enrolling helps us keep conversations relevant to learners.
Cohorts
WebsiteDiscoverBlogPatika.devRise In
CoursesCircleRustSoliditySolanaWeb3 FundamentalsBlockchain Basics
CompanyAbout UsTerms of UsePrivacy PolicyGDPR NoticeCookies
Don't miss any update!

Disclaimer: The information, programs, and events provided on https://cohorts.patika.dev is strictly for upskilling and networking purposes related to the technical infrastructure of blockchain platforms. We do not provide financial or investment advice, nor do we make any representations regarding the value, profitability, or future price of any blockchain or cryptocurrency. Users are encouraged to conduct their own research and consult with licensed financial professionals before engaging in any investment activities. https://cohorts.patika.dev disclaims any responsibility for financial decisions made by users based on the information provided here.

© 2026 Cohorts, All rights reserved