Mari kita bincangkan tentang penggunaan elegan jsx/tsx dalam vue3
Bagaimana untuk menggunakan jsx/tsx secara elegan dalam
vue? Artikel berikut akan memperkenalkan kepada anda penggunaan elegan jsx/tsx dalam vue3. Saya harap ia akan membantu anda!
Saya percaya bahawa react
rakan sudah biasa dengan jsx/tsx
Kini anda juga boleh menggunakan sintaks vue3
dalam jsx/tsx
. [Cadangan berkaitan: tutorial video vuejs]
Pasang pemalam (@vitejs/plugin-vue-jsx)
vite
Secara rasmi dengan syarat Pemalam rasmi menyokong penggunaan vue3
dalam jsx/tsx
, cuma pasang terus.
yarn add @vitejs/plugin-vue-jsx -D
Selepas pemasangan, masukkan kod dalam vite.config.ts
import vueJsx from "@vitejs/plugin-vue-jsx"; export default defineConfig({ plugins: [ vueJsx(), ] })
Selepas konfigurasi, anda boleh menggunakannya dalam projekjsx/tsx
1. Interpolasi
Interpolasi jsx/tsx adalah sama dengan interpolasi dalam sintaks templat vue, menyokong ungkapan Javascript yang sah, seperti: a b
, a || 5
...
Cuma dalam jsx/tsx, pendakap berganda {{}}
telah ditukar kepada pendakap tunggal {}
// vue3模板语法 <span>{{ a + b }}</span> // jsx/tsx <span>{ a + b }</span>
2. Pengikat kelas dan gaya
Terdapat dua cara untuk mengikat nama kelas, menggunakan rentetan templat atau menggunakan tatasusunan.
- Gunakan rentetan templat untuk memisahkan dua nama kelas dengan ruang
// 模板字符串 <div>header</div> //数组 <div>header</div>
Pengikatan gaya memerlukan penggunaan pendakap berganda
const color = 'red' const element = <sapn>style</sapn>
3. Paparan bersyarat
- Hanya arahan
v-show
dikekalkan dalam jsx/tsx, tiada arahanv-if
- Gunakan
if/else
dan tiga Semua ungkapan objek boleh dilaksanakan
setup() { const isShow = false const element = () => { if (isShow) { return <span>我是if</span> } else { return <span>我是else</span> } } return () => ( <div> <span>我是v-show</span> { element() } { isShow ? <p>我是三目1</p> : <p>我是三目2</p> } <div> ) }<h2 id="strong-Paparan-senarai-strong"><strong> 4. Paparan senarai </strong></h2> <p>Begitu juga, tiada arahan <code>v-for</code> dalam jsx/tsx, dan senarai perlu diberikan. Kita hanya perlu menggunakan kaedah tatasusunan Js <code>map</code> </p> <pre class="brush:php;toolbar:false">setup() { const listData = [ {name: 'Tom', age: 18}, {name: 'Jim', age: 20}, {name: 'Lucy', age: 16} ] return () => ( <div> <div> <span>姓名</span> <span>年龄</span> </div> { prop.listData.map(item => { return <div> <span>{item.name}</span> <span>{item.age}</span> </div> }) } </div> ) }
5. digunakan untuk mengikat peristiwa Ia juga merupakan tanda kurung tunggal , tetapi mengikat acara tidak diawali dengan
, tetapi ditukar kepada- Contohnya: acara klik ialah
-
menerima dua parameter Parameter pertama ialah peristiwa terikat, dan parameter kedua ialah peristiwa yang perlu digunakan.{}
@
on
Jika anda perlu menggunakan pengubah suai peristiwa, anda perlu menggunakan kaedahonClick
Kaedah -
6 v-modelwithModifiers
withModifiers
修饰符
setup() { const clickBox = val => { console.log(val) } return () => ( <div> clickBox('box1')}> <span>我是box1</span> <div> clickBox('box2')}> <span>我是box2</span> <div> clickBox('box3'), ['stop'])}>我是box3</div> </div> </div> ) }jsx/tsx menyokong sintaks v-model
<.>7. slot
// 正常写法 <input> // vue <input> // jsx // 指定绑定值写法 <input> // vue <input> // jsx // 修饰符写法 <input> // vue <input> // jsxTentukan slot
Tiada tag
dalam jsx/tsx, anda perlu gunakanuntuk menentukan slot Atau gunakan fungsi
Fungsi persediaan menerima dua parameter secara lalai 1. props 2. konteks ctx yang mengandungi slot, attrs, emit, dll.slot
{}
renderSlot
Gunakan slot
import { renderSlot } from "vue" export default defineComponent({ // 从ctx中解构出来 slots setup(props, { slots }) { return () => ( <div> { renderSlot(slots, 'default') } { slots.title?.() } </div> ) } })
8. Gunakan tsx untuk melaksanakan komponen rekursif - fungsi utama menu
v-slots
ialah Menu yang dijana
import Vslot from './slotTem' export default defineComponent({ setup() { return () => ( <div> <vslot> { return <p>我是title插槽</p> }, default: () => { return <p>我是default插槽</p> } }} /> </vslot> </div> ) } })dijana secara automatik mengikut maklumat penghalaan Kesannya adalah seperti berikut adalah seperti berikut. Jika anda perlu mengawal kebenaran, tambahkannya sendiri dalam
maklumat penghalaan, dan kemudian kawal sendiri dalam
(Video pembelajaran. perkongsian:pembangunan bahagian hadapan web
,Video pengaturcaraan asas)
Atas ialah kandungan terperinci Mari kita bincangkan tentang penggunaan elegan jsx/tsx dalam vue3. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Vue.js adalah rangka kerja JavaScript yang progresif yang sesuai untuk membina antara muka pengguna yang kompleks. 1) Konsep terasnya termasuk data responsif, komponen dan DOM maya. 2) Dalam aplikasi praktikal, ia boleh ditunjukkan dengan membina aplikasi todo dan mengintegrasikan vuerouter. 3) Apabila debugging, disyorkan untuk menggunakan Vuedevtools dan Console.log. 4) Pengoptimuman prestasi boleh dicapai melalui V-IF/V-Show, senarai pengoptimuman rendering, pemuatan asynchronous komponen, dll.

Vue.js sesuai untuk projek kecil dan sederhana, sementara React lebih sesuai untuk aplikasi besar dan kompleks. 1. Sistem responsif vue.js secara automatik mengemas kini DOM melalui pengesanan ketergantungan, menjadikannya mudah untuk menguruskan perubahan data. 2. Leact mengamalkan aliran data sehala, dan data mengalir dari komponen induk ke komponen kanak-kanak, menyediakan aliran data yang jelas dan struktur yang mudah dibuang.

Vue.js sesuai untuk projek kecil dan sederhana dan lelaran yang cepat, sementara React sesuai untuk aplikasi besar dan kompleks. 1) Vue.js mudah digunakan dan sesuai untuk situasi di mana pasukan tidak mencukupi atau skala projek kecil. 2) React mempunyai ekosistem yang lebih kaya dan sesuai untuk projek dengan prestasi tinggi dan keperluan fungsional yang kompleks.

Kaedah untuk melaksanakan lompatan tag dalam Vue termasuk: menggunakan tag dalam templat HTML untuk menentukan atribut HREF. Gunakan komponen router-link routing VUE. Gunakan ini. $ Router.push () kaedah dalam JavaScript. Parameter boleh dilalui melalui parameter pertanyaan dan laluan dikonfigurasikan dalam pilihan penghala untuk lompatan dinamik.

Terdapat kaedah berikut untuk melaksanakan lompat komponen di Vue: Gunakan Router-Link dan & lt; Router-View & GT; Komponen untuk melaksanakan lompat hiperpautan, dan tentukan: untuk atribut sebagai laluan sasaran. Gunakan & lt; router-view & gt; Komponen secara langsung untuk memaparkan komponen yang dijalankan yang sedang dialihkan. Gunakan kaedah router.push () dan router.replace () untuk navigasi programatik. Bekas menjimatkan sejarah dan yang kedua menggantikan laluan semasa tanpa meninggalkan rekod.

Terdapat dua cara untuk melompat elemen div di Vue: Gunakan Vue Router dan tambahkan komponen router-link. Tambah pendengar acara @Click dan panggil ini. $ Router.push () kaedah untuk melompat.

Terdapat dua cara utama untuk lulus data dalam VUE: Props: Data satu arah mengikat, lulus data dari komponen induk ke komponen kanak-kanak. Peristiwa: Lulus data antara komponen menggunakan peristiwa dan peristiwa tersuai.

Vue.js menyediakan tiga cara untuk melompat: API JavaScript asli: Gunakan window.location.href untuk melompat. Vue Router: Gunakan & lt; router-link & gt; tag atau ini. $ router.push () kaedah untuk melompat. VUEX: Pencetus laluan melompat melalui tindakan penghantaran atau mutasi komit.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

SublimeText3 versi Inggeris
Disyorkan: Versi Win, menyokong gesaan kod!

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

mPDF
mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)