Rumah >hujung hadapan web >View.js >Pengenalan praktikal kepada Vue.js: Cara mengulung tatasusunan dan objek

Pengenalan praktikal kepada Vue.js: Cara mengulung tatasusunan dan objek

青灯夜游
青灯夜游ke hadapan
2022-11-15 15:32:451751semak imbas

Pengenalan praktikal kepada Vue.js: Cara mengulung tatasusunan dan objek

Dalam bahagian sebelumnya (Kursus Bahagian 3) kami belajar cara menggunakan v-if dan v-show untuk pemaparan bersyarat. Dalam bahagian ini kita akan belajar bagaimana untuk menggelung tatasusunan dan objek, selain menggunakan beberapa konsep yang kita pelajari sebelum ini.

v-for

v-for ialah salah satu arahan asas Vue dan sebaik sahaja anda mempelajari cara menggunakannya, anda boleh menambah lagi pada Fungsi program anda .

Ringkasnya, v-for ialah gelung for. Jika anda masih tidak tahu apa itu gelung for, gelung for sebenarnya adalah sekeping kod Setiap elemen dalam kod akan dilaksanakan sekali, dan elemen ini biasanya Array(数组) atau Object(对象). .

Hari ini, kita akan mulakan dari awal supaya semua yang kita lakukan mempunyai tujuan yang jelas. Di bawah ialah struktur asas fail index.html kami, yang boleh anda salin dan tampal ke dalam editor anda.

100db36a723c770d327fc0aef2ce13b1

93f0f5c25f18dab9d176bd4f6de5d30e
  b2386ffb911b14667cb8f0f91ea547a7Vue 1016e916e0f7d1e588d4f442bf645aedb2f
9c3bca370b5104690d9ef395f2c5f8d1

6c04bd5ca3fcae76e30b72ad730ca86d
  ab509c080ec9f7ec77efedb1cdcd4bed

  16b28748ea4df4d9c2150843fecfba68

  89fdf195e736e7d681e8695545042be92cacc6d41bbb37262a98f745aa00fbf0

  3f1c4e4b6b16bbbd69b2ee476dc4f83a
    const app = new Vue({
      el: '#app',
      data: {

      },
      methods: {

      }
    });
  2cacc6d41bbb37262a98f745aa00fbf0
36cc49f0c466276486e50c850b7e4956

73a6ac4ed44ffec12cee46588e518a5e

Mari kita cipta tatasusunan ringkas dahulu supaya kita boleh menggunakan gelung untuk mengeluarkan kandungan tatasusunan. Kami akan mencipta harta dalam objek data yang dipanggil permainan. Sudah tentu, anda juga boleh memilih nama yang anda suka???.

data: {
  games: [
    'Super Mario 64',
    'The Legend of Zelda Ocarina of Time',
    'Secret of Mana',
    'Super Metroid'
  ]
},

Sekarang kita telah menyediakan tatasusunan, mari buat teg ff6d136ddc5fdfeffaf53ff6ee95f185 mudah untuk memaparkannya.

<div id="app">
  <ul>
    <li>Game title here</li>
  </ul>
</div>

kelihatan hebat! Sekarang kita perlu memberitahu Vue bahawa kita ingin mengeluarkan sebanyak mungkin tag ff6d136ddc5fdfeffaf53ff6ee95f185 dalam 25edfb22a4f469ecb59f1190150159c6 dengan menggelung melalui tatasusunan.

Dalam bahasa lain, anda mungkin terbiasa dengan gelung 25edfb22a4f469ecb59f1190150159c6 teg seperti ini:

<?php foreach ($game in $games): ?>
  <li><?php echo $game; ?></li>
<?php endforeach; ?>

Balut teg 25edfb22a4f469ecb59f1190150159c6 yang perlu dikeluarkan dalam gelung.

Tetapi dalam Vue, kami boleh mengisytiharkan arahan v-for pada teg yang kami mahu gelung. Mula-mula buat perubahan berikut dalam teg 25edfb22a4f469ecb59f1190150159c6 anda, kemudian kami akan menganalisisnya langkah demi langkah.

<ul>
  <li v-for="game in games">{{ game }}</li>
</ul>

Mari analisa secara terperinci:

  • v-for Perintah itu ditambah terus dalam tag 25edfb22a4f469ecb59f1190150159c6, bukan ff6d136ddc5fdfeffaf53ff6ee95f185 yang kita lihat tadi 🎜> Tag. Sebab untuk menulis ini ialah: "Buat teg games untuk setiap game dalam tatasusunan 25edfb22a4f469ecb59f1190150159c6 kami.

  • Perhatikan bahawa games ialah teg yang kami letakkan sebelum ini , jadi kita perlu menggunakan nama pembolehubah ini data

  • Pembolehubah ini (singular) ditakrifkan oleh diri kita sendiri, kita boleh menggunakan game, , item atau nama lain yang kami fikir sesuai Tetapi anda mesti faham bahawa gamepermainantitle ini ialah pembolehubah yang anda mahu gunakan dalam gelung , dalam teg kami, kami ingin keluarkan kandungan pembolehubah , jadi apabila kita menjalankan gelung, rentetan dalam tatasusunan

    akan dikeluarkan kepada teg
  • secara bergilir-gilir >
  • 25edfb22a4f469ecb59f1190150159c6Buka fail dalam penyemak imbas, anda sepatutnya melihat kandungan tatasusunan game dikeluarkan ke skrin games25edfb22a4f469ecb59f1190150159c6

    Setakat ini, sangat bagus, kan? , tetapi contoh ini membosankan. Mari kita jadikan perkara yang lebih rumit dan menarik. Bagaimana pula dengan memasukkan beberapa objek dalam tatasusunan kami dan menggunakannya dengan
Mula-mula, mari kemas kini sifat

kami dengan beberapa data yang lebih menarik. index.htmlJika anda menjalankan program kami sekarang, ia tidak akan ralat, tetapi ia hanya akan mengeluarkan objek dalam games sebagai rentetan, yang sebenarnya tidak cantik, kami akan memadamkan tag untuk mengeluarkan maklumat kami (jangan risau, ia akan tetap kelihatan hodoh jika anda menggunakan div?)

Ganti keseluruhan dengan kandungan berikut:

<.>?. Adakah anda takut melihat banyak daripada mereka di atas? >v-for Masih sama , kami ingin mengulangi tatasusunan v-if dan menyimpan setiap objek dalam tatasusunan

dalam pembolehubah

.

  • 看看 4a249f0d628e2318394fd9b75b4636b1 标签. 因为 game 是一个对象,而这个对象里又有自己的 nameconsolerating 属性。在 4a249f0d628e2318394fd9b75b4636b1 里面,我们要输出 game 内的 game.namegame.console。正如你现在所看到的那样,v-for 并不像我们之前只输出 25edfb22a4f469ecb59f1190150159c6 标签,实际上你可以根据你的需要输出不同的 HTML 标签。

  • 嵌套的 v-for。在 span 标签里面,我们有一个嵌套的 v-for 循环(这完全是可以的),只是有点不同,在这里我们没有循环数组或对象。而是循环了一个数值(在本例中是 game.rating,循环将根据 game.rating 的值开始计数,然后输出对应数量的❤️。很简单吧?)

  • 最后是 v-if。我们要在循环中输出一个 dc6dce4a544fdca2df29d5ac0ea9906b 标签,只有当前 game.rating 的值大于 5 时,才会输出一个dc6dce4a544fdca2df29d5ac0ea9906b标签。

  • 来吧,在浏览器中继续运行我们的 index.html 文件。

    每次循环时可不可以不使用 DIV ?

    如果你发现写了一大堆 dc6dce4a544fdca2df29d5ac0ea9906b 标签只是为了用 v-for 循环,那么可以使用 d477f9ce7bf77f53fbcf36bec1b69b7a 028402f0d1e2c7f0a5739e0164ec6833 这个特殊的 HTML 标签帮助你解决这个问题。

    现在将带有 v-for 指令的 dc6dce4a544fdca2df29d5ac0ea9906b 标签改成 d477f9ce7bf77f53fbcf36bec1b69b7a 标签,然后打开你的开发者控制台,你会发现 4a249f0d628e2318394fd9b75b4636b145a2772a6b6107b401db3c9b82c049c2 标签没有被任何东西包裹。

    d477f9ce7bf77f53fbcf36bec1b69b7a 很特别,因为 Vue 会把它当作一个只用来封装的标签,当我们执行的时候,它不会被渲染到 HTML 中,所以你可以安全地用它来封装一堆其他元素,而不影响你整体的 HTML 结构。

    :key 属性

    最后一件事::key属性。我特意留到了最后来讲解。

    当你用 v-for 循环时,Vue 不知道如何追踪每个元素,因为它不能将对象区别开来。这意味着 Vue 将重新渲染循环创建的整个部分。在我们的例子中,v-for 只是一个很小的部分,性能损失很小,但这些你应该牢记住。

    现在,我们该如何使用它呢?

    :key 接收字符串或数字来 “命名” 或 “追踪” 这个元素,所以我们需要给它一个唯一的标识符。对于我们的 games 来说,很简单,我们可以这样做:

    <div v-for="game in games" :key="game.name">

    我很确定,我们不会在这个列表中出现两次相同的 game 对象,所以这是相当安全的。如果你有来自数据库的数据,一个唯一的 id 在这里使用也很好。

    如果你对 :key 的原理很好奇,你可以看看文档 Key的文档

    既然你已经了解了这么多,我就再强调下文档的重要性。 Vue 的文档非常出色,文档团队在保持更新和清晰性方面做了很多努力并且通过代码示例把每个部分都解释的非常清楚。

    最终代码

    以防万一,这是最终的代码:

    
    
    
      Vue 101
    
    
    
    
    <div v-for="game in games" :key="game.name">

    {{ game.name }} - {{ game.console }}

    ❤️
    Wow, this game must be REALLY good
    <script> const app = new Vue({ el: &#39;#app&#39;, data: { games: [ { name: &#39;Super Mario 64&#39;, console: &#39;Nintendo 64&#39;, rating: 4 }, { name: &#39;The Legend of Zelda Ocarina of Time&#39;, console: &#39;Nintendo 64&#39;, rating: 5 }, { name: &#39;Secret of Mana&#39;, console: &#39;Super Nintendo&#39;, rating: 4 }, { name: &#39;Fallout 76&#39;, console: &#39;Multiple&#39;, rating: 1 }, { name: &#39;Super Metroid&#39;, console: &#39;Super Nintendo&#39;, rating: 6 } ] } }); </script>

    小测验

    请在 45a2772a6b6107b401db3c9b82c049c2 标签中添加一个 @click 事件,使它每次点击就会增加一个❤️。

    提示: 你需要将正在循环的 game 对象传递给点击方法。

    原文地址:https://dev.to/marinamosti/hands-on-vuejs-for-beginners-part-4-324l

    译文地址:https://www.php.cn/link/5a13fe4ac11f3e35f4b9f0a99cf504c0

    (学习视频分享:web前端开发编程基础视频

    Atas ialah kandungan terperinci Pengenalan praktikal kepada Vue.js: Cara mengulung tatasusunan dan objek. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

    Kenyataan:
    Artikel ini dikembalikan pada:learnku.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam
    Artikel sebelumnya:Artikel untuk bercakap tentang komponen KeepAlive dalam VueArtikel seterusnya:Artikel untuk bercakap tentang komponen KeepAlive dalam Vue

    Artikel berkaitan

    Lihat lagi