찾다
웹 프론트엔드View.jsVue.js에 대한 실용적인 소개: 배열과 객체를 반복하는 방법

Vue.js에 대한 실용적인 소개: 배열과 객체를 반복하는 방법

이전 섹션(과정 3부)에서는 조건부 렌더링에 v-ifv-show를 사용하는 방법을 배웠습니다. 이 섹션에서는 배열과 객체를 반복하는 방법을 배우고, 또한 이전에 배운 개념 중 일부를 적용해 보겠습니다. v-ifv-show 进行条件渲染。本节我们将学习如何对数组和对象进行循环,除此之外,我们还将应用之前所学的一些概念。

v-for

v-for 是 Vue 的基本指令之一,一旦你学会如何使用它,你就可以在你的程序中添加更多功能。

简单的来说,v-for 就是一个 for 循环。如果你还不知道什么是 for 循环的话,for 循环其实是一段代码,代码内每一个元素都会被执行一次,而这些元素通常是一个 Array(数组)Object(对象)

今天,我们要从头开始,这样我们所做的一切都有一个明确的目的。下面是我们的 index.html 文件的基本结构,你可以将它复制粘贴到编辑器中。



  <title>Vue 101</title>



  <div>

  </div>

  <script></script>

  <script>
    const app = new Vue({
      el: &#39;#app&#39;,
      data: {

      },
      methods: {

      }
    });
  </script>


让我们先创建一个简单的数组,这样我们可以使用循环输出数组里的内容。我们将在 data 对象中创建一个属性,叫做 games。当然,你也可以取一个自己喜欢的名字???。

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

现在我们已经设置好了数组,让我们创建一个简单的 <ul></ul> 标签来显示它。

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

看起来很不错! 现在我们要告诉 Vue,我们要通过循环数组在 <ul></ul> 中输出尽可能多的 <li> 标签。

在其他语言中,你可能已经习惯了这样来循环输出 <li> 标签:

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

将需要循环输出的 <li> 标签包裹在循环中。

但是在 Vue 中,我们可以将 v-for 指令声明在我们要循环的标签上。首先在你的 <li> 标签中做下面这些修改,之后我们再来一步步分析。

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

让我们来详细分析一下:

    <li>

    v-for 指令是直接加在 <li> 标签中,而不是我们前面看到的 <ul></ul> 标签。这样写的原因是: “给我们 games 数组中的每一个 game 都创建一个 <li> 标签。

    <li>

    注意,games 是我们前面在 data 中添加的属性,所以我们要用这个变量名。

    <li>

    game 这个变量(单数)是由我们自己定义的,我们可以用 itemgametitle 或者其他我们觉得合适的名称。但是一定要明白,这个 game 是你在循环里面要用的变量。

    <li>

    最后,在我们的 <li> 标签里面,我们要输出 game 变量的内容,所以当我们循环运行的时候,将会依次把 games 数组中的字符串输出到 <li> 标签中。

在浏览器内打开我们的 index.html 文件,你应该会看到 games 数组内的内容被输出到屏幕上。

提升点难度

到目前为止,还算不错吧? v-for 实际上是一个非常简单的概念,但是这个例子太无聊了。让我们把事情变得更复杂有趣一点,在我们的数组中包含一些对象,并配合着 v-if 使用,怎么样?

首先,我们用一些更有趣的数据来更新我们的 games 属性。

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 }
  ]
},

如果你现在运行我们的程序,它不会出错,但它只会以字符串的格式输出 games 里的对象,这不太美观。事实上,我们要彻底删掉我们的 <ul></ul> 标签,用

标签来输出我们的信息。(别担心,用了 div 还是会很难看?)

将整个

替换成如下内容:
<div id="app">
  <div v-for="game in games">
    <h1 id="nbsp-game-name-nbsp-nbsp-nbsp-small-nbsp-game-console-nbsp-small">{{ game.name }} - <small>{{ game.console }}</small></h1>

    <span v-for="star in game.rating">❤️</span>

    <div v-if="game.rating > 5">Wow, this game must be <b>REALLY</b> good</div>
  </div>
</div>

?. 看到上面一大堆是不是很害怕?不用担心,你只需要了解的是什么,让我们详细分析一下:

    <li>

    div v-for="game in games" 还是老样子,我们要循环 games 数组,并将 games 数组内的每个对象存储在 game

    v-for

    v-for는 Vue의 기본 지침 중 하나입니다. 사용법을 익히면 사용할 수 있습니다. 프로그램에 더 많은 기능을 추가하세요. 🎜🎜간단히 말하면 v-forfor 루프입니다. 여전히 for 루프가 무엇인지 모르는 경우 for 루프는 실제로 코드 조각입니다. 코드의 각 요소는 한 번 실행되며 이러한 요소는 일반적으로 Array(array) 또는 Object(object)입니다. 🎜🎜오늘 우리는 우리가 하는 모든 일이 명확한 목적을 갖도록 처음부터 시작합니다. 다음은 편집기에 복사하여 붙여넣을 수 있는 index.html 파일의 기본 구조입니다. 🎜
    <div v-for="game in games" :key="game.name">
    🎜루프를 사용하여 배열의 내용을 출력할 수 있도록 먼저 간단한 배열을 만들어 보겠습니다. games라는 data 개체에 속성을 생성하겠습니다. 물론 원하는 이름을 선택할 수도 있습니다???. 🎜
    
    
    
      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> 🎜이제 배열이 설정되었으므로 이를 표시할 간단한 <ul></ul> 태그를 만들어 보겠습니다. 🎜rrreee🎜멋져요! 이제 배열을 반복하여 <ul></ul>에서 가능한 한 많은 <li> 태그를 출력하고 싶다고 Vue에 알려야 합니다. . 🎜🎜다른 언어에서는 <li> 태그를 반복하는 데 익숙할 수 있습니다. 🎜rrreee🎜루핑해야 하는 <li> 태그를 래핑합니다. 루프에서. 🎜🎜하지만 Vue에서는 반복하려는 태그에 v-for 지시문을 선언할 수 있습니다. 먼저 <li> 태그를 다음과 같이 변경하면 단계별로 분석해 보겠습니다. 🎜rrreee🎜자세히 분석해 보겠습니다. 🎜
    <li>🎜v-for 지시문은 <ul></ul> 태그 대신 li> 태그를 사용하세요. 이 글을 작성하는 이유는 "games 배열의 각 game에 대해 <li> 태그를 생성하기 때문입니다. 🎜🎜 games는 앞서 data에 추가한 속성이므로 이 변수 ​​이름 🎜
<li>🎜 이 변수(단수)는 item, game, title 또는 기타 이름을 사용할 수 있습니다. 하지만 이 게임은 루프에서 사용하려는 변수라는 점을 이해해야 합니다. 🎜 <li>🎜마지막으로 <li code> 태그에서는 <code>game 변수의 내용을 출력하려고 하므로 루프를 실행하면 games 배열의 문자열이 로 출력됩니다. ><li> 태그 🎜
🎜브라우저에서 index.html 파일을 열면 games가 표시됩니다. 배열의 내용이 화면에 출력됩니다. 🎜

난이도를 높이세요

🎜지금까지는 너무 좋습니다 v-for? 실제로는 매우 간단합니다. 하지만 이 예제는 너무 지루합니다. 배열에 일부 개체를 포함하고 v-if<.>를 사용하여 상황을 좀 더 복잡하고 흥미롭게 만들어 보겠습니다. 🎜🎜먼저 <code>를 업데이트해 보겠습니다. 좀 더 흥미로운 데이터가 포함된 games 속성 🎜rrreee🎜지금 프로그램을 실행하면 문제가 발생하지 않지만 games의 개체만 문자열 형식으로 출력됩니다. 실제로 <ul></ul> 태그를 완전히 삭제하고
태그를 사용하여 정보를 출력해야 합니다(걱정하지 마세요. div를 사용하면 여전히 보기 흉하게 보일까요?) 🎜🎜전체
code>가 다음 콘텐츠로 대체됩니다.🎜rrreee🎜? 위에 있는 것 중? 걱정하지 마세요. 그것이 무엇인지만 알면 됩니다. 자세히 분석해 보겠습니다. 🎜
    <li>🎜div v-for=" game in games" 다시 한 번 games 배열을 반복하고 gamegames 배열에 각 개체를 저장하겠습니다. 코드> 변수. 🎜 <li>

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

    <li>

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

    <li>

    最后是 v-if。我们要在循环中输出一个 <div> 标签,只有当前 <code>game.rating 的值大于 5 时,才会输出一个<div>标签。<p>来吧,在浏览器中继续运行我们的 <code>index.html 文件。

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

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

    现在将带有 v-for 指令的 <div> 标签改成 <code><template></template> 标签,然后打开你的开发者控制台,你会发现 <h1></h1><span></span> 标签没有被任何东西包裹。

    <template></template> 很特别,因为 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>

小测验

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

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

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

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

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

위 내용은 Vue.js에 대한 실용적인 소개: 배열과 객체를 반복하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 learnku에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
vue.js Virtual Dom이 변경을 감지하면 어떻게됩니까?vue.js Virtual Dom이 변경을 감지하면 어떻게됩니까?May 14, 2025 am 12:12 AM

whenthevue.jsvirtualdomdetectsachange, itupdatesthevirtualdom, diffsit 및 apppliesminimalchangestotherealdom.이 기능성이 높은 성능 byavoidingunnecessarydommomanipulations.

Vue.js의 가상 Dom을 실제 Dom의 거울로 생각하는 것이 얼마나 정확합니까?Vue.js의 가상 Dom을 실제 Dom의 거울로 생각하는 것이 얼마나 정확합니까?May 13, 2025 pm 04:05 PM

vue.js의 가상은 모두 진짜 돔의 거울이며 정확히 아닙니다. 1. 생성 및 업데이트 : vue.js는 구성 요소 정의를 기반으로 가상 트리를 생성하고 상태가 변경 될 때 먼저 가상을 업데이트합니다. 2. 차이 및 패치 : Diff 작업을 통한 기존 및 새로운 가상의 비교 및 ​​실제 DOM에 최소 변경 사항 만 적용합니다. 3. 효율성 : 가상도는 배치 업데이트를 허용하고 직접 DOM 운영을 줄이며 렌더링 프로세스를 최적화합니다. Virtualdom은 vue.js가 UI 업데이트를 최적화 할 수있는 전략적 도구입니다.

vue.js vs. React : 확장 성과 유지 가능성vue.js vs. React : 확장 성과 유지 가능성May 10, 2025 am 12:24 AM

vue.js와 반응은 각각 확장 성과 유지 가능성에 고유 한 장점이 있습니다. 1) vue.js는 사용하기 쉽고 소규모 프로젝트에 적합합니다. Composition API는 대규모 프로젝트의 유지 보수성을 향상시킵니다. 2) RECT는 크고 복잡한 프로젝트에 적합하며, 후크와 가상 DOM은 성능과 유지 관리를 향상시킬 수 있지만 학습 곡선은 더 가파릅니다.

vue.js and React의 미래 : 트렌드와 예측vue.js and React의 미래 : 트렌드와 예측May 09, 2025 am 12:12 AM

vue.js 및 React의 미래 추세와 예측은 다음과 같습니다. 1) vue.js는 엔터프라이즈 레벨 애플리케이션에서 널리 사용되며 서버 측 렌더링 및 정적 사이트 생성에서 획기적인 결과를 얻었습니다. 2) RECT는 서버 구성 요소 및 데이터 수집에서 혁신하고 동시성 모델을 더욱 최적화합니다.

Netflix의 프론트 엔드 : 기술 스택에 대한 깊은 다이빙Netflix의 프론트 엔드 : 기술 스택에 대한 깊은 다이빙May 08, 2025 am 12:11 AM

Netflix의 프론트 엔드 기술 스택은 주로 React 및 Redux를 기반으로합니다. 1. 반응은 고성능 단일 페이지 응용 프로그램을 구축하는 데 사용되며 구성 요소 개발을 통해 코드 재사용 성 및 유지 보수를 향상시킵니다. 2. Redux는 상태 변경이 예측 가능하고 추적 할 수 있도록 국가 관리에 사용됩니다. 3. 도구 체인에는 코드 품질과 성능을 보장하기위한 웹 팩, 바벨, 농담 및 효소가 포함됩니다. 4. 성능 최적화는 코드 세분화, 게으른로드 및 서버 측 렌더링을 통해 사용자 경험을 향상시킵니다.

vue.js 및 프론트 엔드 : 대화식 사용자 인터페이스 구축vue.js 및 프론트 엔드 : 대화식 사용자 인터페이스 구축May 06, 2025 am 12:02 AM

vue.js는 대화 형 사용자 인터페이스를 구축하는 데 적합한 점진적인 프레임 워크입니다. 핵심 기능에는 응답 시스템, 구성 요소 개발 및 라우팅 관리가 포함됩니다. 1) 응답 시스템은 Object.DefineProperty 또는 프록시를 통한 데이터 모니터링을 실현하고 인터페이스를 자동으로 업데이트합니다. 2) 구성 요소 개발을 통해 인터페이스를 재사용 가능한 모듈로 분할 할 수 있습니다. 3) Vuerouter는 단일 페이지 응용 프로그램을 지원하여 사용자 경험을 향상시킵니다.

vuejs의 단점은 무엇입니까?vuejs의 단점은 무엇입니까?May 05, 2025 am 12:06 AM

vue.js의 주요 단점은 다음과 같습니다. 1. 생태계는 비교적 새롭고 타사 라이브러리와 도구는 다른 프레임 워크만큼 풍부하지 않습니다. 2. 학습 곡선은 복잡한 기능에서 가파르게됩니다. 3. 지역 사회 지원과 자원은 반응과 각도만큼 광범위하지 않다. 4. 대규모 응용 프로그램에서 성능 문제가 발생할 수 있습니다. 5. 버전 업그레이드 및 호환성 문제가 더 큽니다.

Netflix : 프론트 엔드 프레임 워크를 공개합니다Netflix : 프론트 엔드 프레임 워크를 공개합니다May 04, 2025 am 12:16 AM

Netflix는 React를 프론트 엔드 프레임 워크로 사용합니다. 1. 반응의 구성 요소 개발 및 가상 DOM 메커니즘은 성능 및 개발 효율성을 향상시킵니다. 2. Webpack 및 Babel을 사용하여 코드 구성 및 배포를 최적화하십시오. 3. 성능 최적화를 위해 코드 세분화, 서버 측 렌더링 및 캐싱 전략을 사용하십시오.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.