Metadata
Next.js, gelişmiş SEO ve web paylaşılabilirliği için uygulama meta verilerinizi (örneğin HTML head öğenizin içindeki meta
ve link
etiketleri) tanımlamak için kullanılabilecek bir Meta Veri API'sine sahiptir.
Uygulamanıza meta veri eklemenin iki yolu vardır:
Yapılandırma Tabanlı Meta Veriler: Statik bir
meta
veri nesnesini veya dinamik birgenerateMetadata
işlevini birlayout.js
veyapage.js
dosyasına aktarınDosya Tabanlı Meta Veriler: Rota segmentlerine statik veya dinamik olarak oluşturulan özel dosyalar ekleyin.
Bu iki seçenekle de Next.js sayfalarınız için ilgili <head>
öğelerini otomatik olarak oluşturacaktır. ImageResponse
yapıcısını kullanarak dinamik OG görüntüleri de oluşturabilirsiniz
Statik Meta Veriler
Statik meta verileri tanımlamak için bir layout.js
veya static page.js
dosyasından bir Meta Veri nesnesini dışa aktarın.
Dinamik Meta Veriler
Dinamik değerler gerektiren meta verileri fetch
etmek için generateMetadata
işlevini kullanabilirsiniz.
Bilmekte fayda var:
generateMetadata
aracılığıyla hem statik hem de dinamik meta veriler yalnızca Sunucu Bileşenlerinde desteklenir.Next.js, bir rota render ederken
generateMetadata
,generateStaticParam
, Layouts, Pages ve Sunucu Bileşenlerinde aynı veriler için getirme isteklerini otomatik olarak tekilleştirir.fetch
kullanılamıyorsa Reactcache
kullanılabilirNext.js, istemciye UI akışı yapmadan önce
generateMetadata
içindeki veri getirme işleminin tamamlanmasını bekler. Bu, akışlı bir yanıtın ilk bölümünün<head>
etiketlerini içermesini garanti eder.
Dosya tabanlı meta veriler
Bu özel dosyalar meta veriler için kullanılabilir:
favicon.ico, apple-icon.jpg ve icon.jpg
opengraph-image.jpg ve twitter-image.jpg
robots.txt
sitemap.xml
Bunları statik meta veriler için kullanabilir veya bu dosyaları kodla programlı olarak oluşturabilirsiniz.
Davranış
Dosya tabanlı meta veriler daha yüksek önceliğe sahiptir ve yapılandırma tabanlı meta verileri geçersiz kılar.
Varsayılan Alanlar
Bir rota meta veri tanımlamasa bile her zaman eklenen iki varsayılan meta
etiket vardır:
Meta charset etiketi web sitesi için karakter kodlamasını ayarlar.
Meta viewport etiketi, web sitesinin farklı cihazlara göre ayarlanması için görüntü alanı genişliğini ve ölçeğini ayarlar.
Bilmekte fayda var: Varsayılan viewport
meta etiketinin üzerine yazabilirsiniz.
Sıralama (Ordering)
Meta veriler, kök segmentten başlayarak son page.js segmentine en yakın segmente kadar sırayla değerlendirilir. Örneğin:
app/layout.tsx
(Kök Düzen)app/blog/layout.tsx
(İç İçe Blog Düzeni)app/blog/[slug]/page.tsx
(Blog Sayfası)
Birleştirme
Değerlendirme sırasını takiben, aynı rotadaki birden fazla segmentten dışa aktarılan Meta Veri nesneleri, bir rotanın nihai meta veri çıktısını oluşturmak için yüzeysel olarak birleştirilir. Yinelenen anahtarlar sıralamalarına göre değiştirilir.
Bu, daha önceki bir segmentte tanımlanan openGraph
ve robotlar
gibi iç içe geçmiş alanlara sahip meta verilerin, bunları tanımlayan son segment tarafından üzerine yazıldığı anlamına gelir.
Alanların üzerine yazma (Overwriting Fields)
Yukarıdaki örnekte:
app/layout.js
dosyasındakititle
,app/blog/page.js
dosyasındaki title ile değiştirilir.app/layout.js
'deki tümopenGraph
alanlarıapp/blog/page.js
'de değiştirilir çünküapp/blog/page.js
openGraph
meta verilerini ayarlar.openGraph.description
'ın olmadığına dikkat edin.
Bazı iç içe geçmiş alanları segmentler arasında paylaşırken diğerlerinin üzerine yazmak isterseniz, bunları ayrı bir değişkene çekebilirsiniz:
Yukarıdaki örnekte, OG görüntüsü app/layout.js
ve app/about/page.js
arasında paylaşılırken başlıklar farklıdır.
Devralınan alanlar (Inheriting fields)
Notlar:
app/layout.js
'dekititle
,app/about/page.js
'dekititle
ile değiştirilir.app/about/page.js
openGraph
meta verilerini ayarlamadığı içinapp/layout.js
'deki tümopenGraph
alanlarıapp/about/page.js
'de miras alınır.
Dinamik Görüntü Oluşturma (Dynamic Image Generation)
ImageResponse
yapıcısı, JSX ve CSS kullanarak dinamik görüntüler oluşturmanıza olanak tanır. Bu, Open Graph görüntüleri, Twitter kartları ve daha fazlası gibi sosyal medya görüntüleri oluşturmak için kullanışlıdır.
ImageResponse
, Edge Runtime'ı kullanır ve Next.js, edge'de önbelleğe alınan görüntülere doğru başlıkları otomatik olarak ekleyerek performansı artırmaya ve yeniden hesaplamayı azaltmaya yardımcı olur.
ImageResponse
'u kullanmak için next/server
'dan içe aktarabilirsiniz:
ImageResponse
, Rota İşleyicileri ve dosya tabanlı Meta Veriler dahil olmak üzere diğer Next.js API'leri ile iyi bir şekilde entegre olur. Örneğin, derleme zamanında veya istek zamanında dinamik olarak Open Graph görüntüleri oluşturmak için ImageResponse
'u bir opengraph-image.tsx
dosyasında kullanabilirsiniz.
ImageResponse
, flexbox ve mutlak konumlandırma, özel yazı tipleri, metin kaydırma, merkezleme ve iç içe görüntüler gibi yaygın CSS özelliklerini destekler.
Bilmekte fayda var:
Örnekler Vercel OG Playground'da mevcuttur.
ImageResponse
, HTML ve CSS'yi PNG'ye dönüştürmek için @vercel/og, Satori ve Resvg kullanırYalnızca Edge Çalışma Zamanı desteklenir. Varsayılan Node.js çalışma zamanı çalışmayacaktır.
Yalnızca flexbox ve CSS özelliklerinin bir alt kümesi desteklenir. Gelişmiş düzenler (örn.
display: grid
) çalışmayacaktır.Maksimum paket boyutu
500KB
. Paket boyutu JSX, CSS, yazı tipleri, resimler ve diğer tüm varlıkları içerir. Sınırı aşarsanız, varlıkların boyutunu küçültmeyi veya çalışma zamanında getirmeyi düşünün.Yalnızca
ttf
,otf
vewoff
yazı tipi biçimleri desteklenir. Font ayrıştırma hızını en üst düzeye çıkarmak içinwoff
yerinettf
veyaotf
tercih edilir.
JSON-LD
JSON-LD, içeriğinizi anlamak için arama motorları tarafından kullanılabilen yapılandırılmış veriler için bir formattır. Örneğin, bir kişiyi, bir olayı, bir organizasyonu, bir filmi, bir kitabı, bir tarifi ve diğer birçok varlık türünü tanımlamak için kullanabilirsiniz.
JSON-LD için şu anki önerimiz, yapılandırılmış verileri layout.js
veya page.js
bileşenlerinizde bir <script>
etiketi olarak işlemektir.
Örneğin:
Yapılandırılmış verilerinizi Google için Zengin Sonuçlar Testi veya genel Şema İşaretleme Doğrulayıcısı ile doğrulayabilir ve test edebilirsiniz.
JSON-LD'nizi, schema-dts gibi topluluk paketlerini kullanarak TypeScript ile yazabilirsiniz:
Last updated