Statik Dışa Aktarmalar (Static Exports)
Next.js, statik bir site veya Tek Sayfalı Uygulama (SPA) olarak başlamayı ve daha sonra isteğe bağlı olarak sunucu gerektiren özellikleri kullanmak için yükseltmeyi sağlar.
Next.js, next build
çalıştırırken her rota için bir HTML dosyası oluşturur. Next.js, katı bir SPA'yı ayrı HTML dosyalarına bölerek istemci tarafında gereksiz JavaScript kodlarının yüklenmesini önleyebilir, paket boyutunu küçültebilir ve sayfanın daha hızlı yüklenmesini sağlayabilir.
Next.js bu statik dışa aktarımı desteklediğinden, HTML/CSS/JS statik varlıklarını sunabilen herhangi bir web sunucusunda dağıtılabilir ve barındırılabilir.
Konfigürasyon
Statik dışa aktarmayı etkinleştirmek için next.config.js
içindeki çıktı modunu değiştirin:
Next.js, next build
çalıştırdıktan sonra uygulamanız için HTML/CSS/JS varlıklarını içeren bir out
klasörü üretecektir.
Desteklenen Özellikler
Next.js'nin çekirdeği statik dışa aktarımları desteklemek üzere tasarlanmıştır.
Sunucu Bileşenleri
Statik dışa aktarma oluşturmak için next build
çalıştırdığınızda, app
dizini içinde tüketilen Sunucu Bileşenleri, geleneksel statik site oluşturmaya benzer şekilde derleme sırasında çalışacaktır.
Ortaya çıkan bileşen, ilk sayfa yüklemesi için statik HTML'ye ve rotalar arasında istemci gezintisi için statik bir yüke dönüştürülecektir. Dinamik sunucu işlevlerini kullanmadıkları sürece, statik dışa aktarmayı kullanırken Sunucu Bileşenleriniz için hiçbir değişiklik gerekmez.
İstemci Bileşenleri
İstemcide veri getirme işlemi gerçekleştirmek istiyorsanız, istekleri memoize etmek için SWR ile bir İstemci Bileşeni kullanabilirsiniz.
Rota geçişleri istemci tarafında gerçekleştiğinden, bu geleneksel bir SPA gibi davranır. Örneğin, aşağıdaki dizin rotası istemcide farklı gönderilere gitmenizi sağlar:
Görüntü Optimizasyonu
next/image
aracılığıyla Görüntü Optimizasyonu, next.config.js
'de özel bir görüntü yükleyici tanımlayarak statik bir dışa aktarma ile kullanılabilir. Örneğin, Cloudinary gibi bir hizmetle görüntüleri optimize edebilirsiniz:
Bu özel yükleyici, görüntülerin uzak bir kaynaktan nasıl alınacağını tanımlayacaktır. Örneğin, aşağıdaki yükleyici Cloudinary için URL oluşturacaktır:
Daha sonra uygulamanızda next/image
öğesini kullanarak Cloudinary'deki görüntüye göreli yollar tanımlayabilirsiniz:
Rota İşleyicileri
Rota İşleyicileri next build
çalıştırırken statik bir yanıt oluşturacaktır. Yalnızca GET
HTTP fiili desteklenir. Bu, önbelleğe alınmış veya önbelleğe alınmamış verilerden statik HTML, JSON, TXT veya diğer dosyaları oluşturmak için kullanılabilir. Örneğin:
Yukarıdaki app/data.json/route.ts
dosyası next build
sırasında statik bir dosyaya dönüştürülecek ve { name: 'Lee' }
içeren data.json
dosyası oluşturulacaktır.
Gelen istekten dinamik değerleri okumanız gerekiyorsa, statik bir dışa aktarma kullanamazsınız.
Tarayıcı API'leri
İstemci Bileşenleri next build
sırasında HTML'ye önceden oluşturulur. window
, localStorage
ve navigator
gibi Web API'leri sunucuda bulunmadığından, bu API'lere yalnızca tarayıcıda çalışırken güvenli bir şekilde erişmeniz gerekir. Örneğin:
Desteklenmeyen Özellikler
Node.js sunucusu gerektiren özellikler veya derleme işlemi sırasında hesaplanamayan dinamik mantık desteklenmez:
dynamicParams ile
dynamicParams: true
generateStaticParams()
olmadan Dinamik Rotalarİstek'e dayanan Rota İşleyicileri
Çerezler
Yeniden Yazma
Yönlendirmeler
Başlıklar
Orta Yazılım
Artımlı Statik Rejenerasyon
Varsayılan
loader
ile Görüntü OptimizasyonuTaslak Modu
Bu özelliklerden herhangi birinin next dev
ile kullanılmaya çalışılması, kök düzende dynamic
seçeneğinin error
olarak ayarlanmasına benzer şekilde bir hatayla sonuçlanacaktır.
Dağıtım (Deploying)
Statik bir dışa aktarma ile Next.js, HTML/CSS/JS statik varlıkları sunabilen herhangi bir web sunucusunda dağıtılabilir ve barındırılabilir.
Next.js, next build
çalıştırırken statik dışa aktarımı out
klasörüne oluşturur. Artık next export
kullanmaya gerek yoktur. Örneğin, aşağıdaki rotalara sahip olduğunuzu varsayalım:
/
/blog/[id]
Next.js, next build
çalıştırdıktan sonra aşağıdaki dosyaları oluşturacaktır:
/out/index.html
/out/404.html
/out/blog/post-1.html
/out/blog/post-2.html
Nginx gibi statik bir ana bilgisayar kullanıyorsanız, gelen isteklerden doğru dosyalara yeniden yazmaları yapılandırabilirsiniz:
Last updated