<link>
komponen <link>
bawaan peramban memungkinkan Anda menggunakan sumber daya eksternal seperti stylesheet atau memberi anotasi pada dokumen dengan metadata tautan.
<link rel="icon" href="favicon.ico" />
Referensi
<link>
Untuk menautkan ke sumber daya eksternal seperti stylesheet, font, dan ikon, atau untuk memberi anotasi pada dokumen dengan metadata tautan, renderlah komponen <link>
bawaan peramban. Anda dapat merender <link>
dari komponen mana pun dan React dalam kebanyakan kasus akan menempatkan elemen DOM yang sesuai di bagian kepala dokumen.
<link rel="icon" href="favicon.ico" />
Lihat lebih banyak contoh di bawah ini.
Properti
<link>
mendukung semua properti elemen umum.
rel
: string, dibutuhkan. Menentukan hubungan dengan sumber daya. React memperlakukan tautan dengan rel=“stylesheet” secara berbeda dari tautan lainnya.
Properti-properti ini berlaku ketika rel="stylesheet"
:
precedence
: string. Memberitahu React di mana peringkat node DOM<link>
relatif terhadap yang lain di dokumen<head>
, yang menentukan stylesheet mana yang dapat menimpa yang lain. React akan menyimpulkan bahwa nilai precedence yang ditemukan pertama kali adalah “lebih rendah” dan nilai precedence yang ditemukan kemudian adalah “lebih tinggi”. Banyak sistem gaya dapat berfungsi dengan baik menggunakan satu nilai precedence karena aturan gaya bersifat atomik. Stylesheet dengan precedence yang sama akan dikelompokkan bersama baik mereka adalah tag<link>
atau tag<style>
inline atau dimuat menggunakan fungsipreinit
.media
: string. Membatasi stylesheet pada media query tertentu.title
: string. Menentukan nama dari stylesheet alternatif.
Properti-properti ini berlaku ketika rel="stylesheet"
tetapi menonaktifkan perlakuan khusus stylesheet
oleh React:
disabled
: boolean. Menonaktifkan stylesheet.
onError
: fungsi. Dipanggil ketika stylesheet gagal dimuat.
onLoad
: fungsi. Dipanggil ketika stylesheet selesai dimuat.
Properti-properti ini berlaku ketika rel="preload"
atau rel="modulepreload"
:
as
: string. Jenis sumber daya. Nilai yang mungkin adalah audio
, document
, embed
, fetch
, font
, image
, object
, script
, style
, track
, video
, worker
.
imageSrcSet
: string. Berlaku hanya ketika as="image"
. Menentukan source set dari gambar.
imageSizes
: string. Berlaku hanya ketika as=“image”. Menentukan ukuran gambar.
Properti-properti ini berlaku ketika rel="icon"
atau rel="apple-touch-icon"
:
sizes
: string. Ukuran ikon.
Properti-properti ini berlaku dalam semua kasus:
href
: string. URL dari sumber daya yang ditautkan.crossOrigin
: string. Kebijakan CORS yang digunakan. Nilai yang mungkin adalahanonymous
danuse-credentials
. Diperlukan ketikaas
diatur ke"fetch"
.referrerPolicy
: string. Header Referrer yang dikirim saat mengambil. Nilai yang mungkin adalahno-referrer-when-downgrade
(default),no-referrer
,origin
,origin-when-cross-origin
, danunsafe-url
.fetchPriority
: string. Menyarankan prioritas relatif untuk mengambil sumber daya. Nilai yang mungkin adalahauto
(default),high
, danlow
.hrefLang
: string. Bahasa dari sumber daya yang ditautkan.integrity
: string. Hash kriptografi dari sumber daya, untuk memverifikasi keasliannya.type
: string. Tipe MIME dari sumber daya yang ditautkan.
Properti yang tidak direkomendasikan untuk digunakan dengan React:
blocking
: string. Jika diatur ke"render"
, instruksikan browser untuk tidak merender halaman sampai stylesheet dimuat. React memberikan kontrol yang lebih halus menggunakan Suspense.
Perilaku rendering khusus
React akan selalu menempatkan elemen DOM yang sesuai dengan komponen <link>
di dalam <head>
dokumen, terlepas dari di mana dalam pohon React itu dirender. <head>
adalah satu-satunya tempat valid untuk <link>
dalam DOM, namun ini sesuai dan menjaga hal-hal tetap dapat dikomposisikan jika sebuah komponen yang mewakili halaman tertentu dapat merender komponen <link>
itu sendiri.
Ada beberapa pengecualian untuk ini:
- Jika
<link>
memiliki propertirel="stylesheet"
, maka harus juga memiliki propertiprecedence
untuk mendapatkan perilaku khusus ini. Ini karena urutan stylesheet dalam dokumen adalah signifikan, sehingga React perlu tahu bagaimana mengatur stylesheet ini relatif terhadap yang lain, yang Anda tentukan menggunakan propertiprecedence
. Jika propertiprecedence
dihilangkan, tidak ada perilaku khusus. - Jika
<link>
memiliki propertiitemProp
, tidak ada perilaku khusus, karena dalam kasus ini tidak berlaku untuk dokumen tetapi mewakili metadata tentang bagian spesifik dari halaman. - Jika
<link>
memiliki propertionLoad
atauonError
, karena dalam kasus ini Anda mengelola pemuatan sumber daya yang ditautkan secara manual dalam komponen React Anda.
Perilaku khusus untuk stylesheet
Selain itu, jika <link>
menuju stylesheet (yaitu, memiliki rel="stylesheet"
dalam propertinya), React memperlakukannya secara khusus dalam cara berikut:
- Komponen yang merender
<link>
akan menangguhkan saat stylesheet sedang dimuat. - Jika beberapa komponen merender tautan ke stylesheet yang sama, React akan menghapus duplikatnya dan hanya menempatkan satu tautan ke dalam DOM. Dua tautan dianggap sama jika mereka memiliki properti
href
yang sama.
Ada dua pengecualian untuk perilaku khusus ini:
- Jika tautan tidak memiliki properti
precedence
, tidak ada perilaku khusus, karena urutan stylesheet dalam dokumen ialah penting, sehingga React perlu tahu bagaimana mengatur stylesheet ini relatif terhadap yang lain, yang Anda tentukan menggunakan propertiprecedence
. - Jika Anda memberikan salah satu dari properti
onLoad
,onError
, ataudisabled
, tidak ada perilaku khusus, karena properti ini menunjukkan bahwa Anda mengelola pemuatan stylesheet secara manual dalam komponen Anda.
Perlakuan khusus ini memiliki dua peringatan:
- React akan mengabaikan perubahan pada semua properti setelah tautan dirender. (React akan mengeluarkan peringatan dalam pengembangan jika ini terjadi.)
- React dapat meninggalkan tautan dalam DOM bahkan setelah komponen yang merendernya dihapus.
Penggunaan
Menautkan ke sumber daya terkait
Anda dapat memberi anotasi pada dokumen dengan tautan ke sumber daya terkait seperti ikon, URL kanonik, atau pingback. React akan menempatkan metadata ini di dalam <head>
dokumen terlepas dari di mana dalam pohon React itu dirender.
import ShowRenderedHTML from './ShowRenderedHTML.js'; export default function BlogPage() { return ( <ShowRenderedHTML> <link rel="icon" href="favicon.ico" /> <link rel="pingback" href="http://www.example.com/xmlrpc.php" /> <h1>Blog saya</h1> <p>...</p> </ShowRenderedHTML> ); }
Menautkan ke stylesheet
Jika sebuah komponen bergantung pada stylesheet tertentu agar dapat ditampilkan dengan benar, Anda dapat merender tautan ke stylesheet tersebut di dalam komponen. Komponen Anda akan menangguhkan saat stylesheet sedang dimuat. Anda harus menyertakan properti precedence
, yang memberi tahu React di mana harus menempatkan stylesheet ini relatif terhadap yang lain — stylesheet dengan precedence lebih tinggi dapat menimpa yang dengan precedence lebih rendah.
import ShowRenderedHTML from './ShowRenderedHTML.js'; export default function SiteMapPage() { return ( <ShowRenderedHTML> <link rel="stylesheet" href="sitemap.css" precedence="medium" /> <p>...</p> </ShowRenderedHTML> ); }
Mengontrol precedence stylesheet
Stylesheet dapat bertentangan satu sama lain, dan ketika itu terjadi, peramban akan memilih yang datang kemudian dalam dokumen. React memungkinkan Anda mengendalikan urutan stylesheet dengan properti precedence
. Dalam contoh ini, dua komponen merender stylesheet, dan yang memiliki precedence lebih tinggi akan muncul kemudian dalam dokumen meskipun komponen yang merendernya datang lebih awal.
import ShowRenderedHTML from './ShowRenderedHTML.js'; export default function HalamanRumah() { return ( <ShowRenderedHTML> <KomponenPertama /> <KomponenKedua /> ... </ShowRenderedHTML> ); } function KomponenPertama() { return <link rel="stylesheet" href="first.css" precedence="high" />; } function KomponenKedua() { return <link rel="stylesheet" href="second.css" precedence="low" />; }
Merender stylesheet yang dihapus duplikatnya
Jika Anda merender stylesheet yang sama dari beberapa komponen, React hanya akan menempatkan satu <link>
di bagian kepala dokumen.
import ShowRenderedHTML from './ShowRenderedHTML.js'; export default function HalamanRumah() { return ( <ShowRenderedHTML> <Komponen /> <Komponen /> ... </ShowRenderedHTML> ); } function Komponen() { return <link rel="stylesheet" href="styles.css" precedence="medium" />; }
Memberi anotasi pada item tertentu dalam dokumen dengan tautan
Anda dapat menggunakan komponen <link>
dengan properti itemProp
untuk memberi anotasi pada item tertentu dalam dokumen dengan tautan ke sumber daya terkait. Dalam hal ini, React tidak akan menempatkan anotasi ini di dalam <head>
dokumen tetapi akan menempatkannya seperti komponen React lainnya.
<section itemScope>
<h3>Memberi anotasi terhadap item tertentu</h3>
<link itemProp="penulis" href="http://example.com/" />
<p>...</p>
</section>