vue官方文档 v-for学习笔记

官方文档地址

列表渲染 https://cn.vuejs.org/v2/guide/list.html

简述

通过练习文档中例子,掌握以下知识点:

  • v-for 的基础用法
  • v-for 遍历对象的方法
  • v-for 遍历对象 (A,B,C)分别代表 A-属性值 B-属性名 C-索引值
  • 数组更新的七个方法,这些方法可以原地更新数组的值
    • push()
    • pop()
    • shift()
    • unshift()
    • splice()
    • sort()
    • reverse()
  • 替换数组的方法,这些方法不能原地更新数组值
  • 对数组应用计算属性

练习代码

<template>
  <div class="about">
    <h1>v-for列表渲染</h1>
    <hr />
    <h3>基础用法</h3>
    <ul id="example-1">
      <li v-for="item in items" :key="item.message">{{item.message}}</li>
    </ul>
    <h3>带index索引</h3>
    <ul id="example-1">
      <li v-for="(item,index) in items" :key="item.message">{{index}} - {{item.message}}</li>
    </ul>
    <hr />
    <h3>遍历对象</h3>
    <ul id="v-for-object" class="demo">
      <li v-for="value in object" :key="value">{{value}}</li>
    </ul>
    <h3>带属性名</h3>
    <ul id="v-for-object" class="demo">
      <li v-for="(value,title) in object" :key="value">{{title}} : {{value}}</li>
    </ul>
    <h3>带index</h3>
    <ul id="v-for-object" class="demo">
      <li v-for="(value,title,index) in object" :key="value">{{index}} {{title}} : {{value}}</li>
    </ul>
    <hr />
    <h3>数组更新</h3>
    <button @click="arrPush">push</button>
    <button @click="arrPop">pop</button>
    <button @click="arrShift">shift</button>
    <button @click="arrUnshift">unshift</button>
    <button @click="arrSplice">splice</button>
    <button @click="arrSort">sort</button>
    <button @click="arrReverse">reverse</button>
    <button @click="arrFilter">保留偶数</button>
    <ul>
      <li v-for="(num,index) in numbers" :key="index">{{num}}</li>
    </ul>
    <hr />
    <h3>计算属性</h3>
    <ul>
      <li v-for="(num,index) in evenNumbers" :key="index">{{num}}</li>
    </ul>
    <hr />
    <h3>for循环中使用方法</h3>
    <ul v-for="(set,index) in sets" :key="index">
      <li v-for="n in even(set)" :key="n">{{ n }}</li>
    </ul>
    <hr />
    <h3>v-for使用值范围</h3>
    <div>
      <span v-for="n in 10" :key="n">{{n}}</span>
    </div>
    <hr />
    <h3>template使用v-for渲染一段元素:测试证明这样写不行,key只能写在ul上</h3>
    <ul v-for="item in items" :key="item.message">
      <template>
        <li>{{ item.message }}</li>
        <li class="divider" role="presentation"></li>
      </template>
    </ul>
  </div>
</template>
<script>
export default {
  data() {
    return {
      items: [{ message: "Foo" }, { message: "Bar" }],
      object: {
        title: "How to do lists in Vue",
        author: "Jane Doe",
        publishedAt: "2016-04-10"
      },
      numbers: [1, 5, 2, 3],
      sets: [
        [1, 2, 3, 4, 5],
        [6, 7, 8, 9, 10]
      ]
    };
  },
  methods: {
    arrPush() {
      this.numbers.push(4);
    },
    arrPop() {
      this.numbers.pop();
    },
    arrShift() {
      this.numbers.shift();
    },
    arrUnshift() {
      this.numbers.unshift(9);
    },
    arrSplice() {
      //替换可用这个方法
      this.numbers.splice(0, 2, 10, 20);
    },
    arrSort() {
      this.numbers.sort();
    },
    arrReverse() {
      this.numbers.reverse();
    },
    arrFilter() {
      this.numbers = this.numbers.filter(function(item) {
        return item % 2 === 0;
      });
    },
    even(nums) {
      return nums.filter(function(num) {
        return num % 2 === 0;
      });
    }
  },
  computed: {
    evenNumbers: function() {
      return this.numbers.filter(function(item) {
        return item % 2 === 0;
      });
    }
  }
};
</script>
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容

  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,211评论 0 4
  • 概要 64学时 3.5学分 章节安排 电子商务网站概况 HTML5+CSS3 JavaScript Node 电子...
    阿啊阿吖丁阅读 9,095评论 0 3
  • 一、了解Vue.js 1.1.1 Vue.js是什么? 简单小巧、渐进式、功能强大的技术栈 1.1.2 为什么学习...
    蔡华鹏阅读 3,311评论 0 3
  • 1. Vue 实例 1.1 创建一个Vue实例 一个 Vue 应用由一个通过 new Vue 创建的根 Vue 实...
    王童孟阅读 1,013评论 0 2
  • 《如梦令·遥夜沉沉如水》 [宋 ]秦观 遥夜沉沉如水, 风紧驿亭深闭。 梦破鼠窥灯, 霜送晓寒侵被。 无寐、无寐,...
    天水一色_1a16阅读 169评论 1 7