河南在线欢迎您!
河南在线>微商>正文

「vue干货1」循环,计算属性,事件处理器

2020-03-28 08:35:36 来源: 阅读:1

Vue干货第一集:

v-for 循环
  • v-for 指令需要以 site in sites 形式的特殊语法, sites 是源数据数组并且 site 是数组元素迭代的别名。
  • v-for 可以绑定数据到数组来渲染一个列表:
<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>循环</title>    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">    <meta name="apple-mobile-web-app-capable" content="yes">    <meta name="apple-mobile-web-app-status-bar-style" content="black">    <style>    </style>    <script src="vue.js"></script>    <script>        window.onload=function(){            new Vue({                el:'#box',                data:{                    arr:['apple','banana','orange','pear'],                    json:{a:'apple',b:'banana',c:'orange'}                }            });        };    </script></head><body>    <div id="box">        <ul>            <li v-for="value in arr">                {{value}}            </li>        </ul>    </div></body></html>
  • 模板中使用 v-for:
<template v-for="site in sites">    <li>{{ site.name }}</li>    <li>--------------</li>  </template>
  • v-for 可以通过一个对象的属性来迭代数据:

  • v-for 也可以循环整数
  <li v-for="n in 10">     {{ n }}    </li>
computed 计算属性
<div id="app">  <p>原始字符串: {{ message }}</p>  <p>计算后反转字符串: {{ reversedMessage }}</p></div> <script>var vm = new Vue({  el: '#app',  data: {    message: 'Runoob!'  },  computed: {    // 计算属性的 getter    reversedMessage: function () {      // `this` 指向 vm 实例      return this.message.split('').reverse().join('')    }  }})</script>

实例中声明了一个计算属性 reversedMessage 。
提供的函数将用作属性 vm.reversedMessage 的 getter 。
vm.reversedMessage 依赖于 vm.message,在 vm.message 发生改变时,vm.reversedMessage 也会更新。

事件处理器
  • 事件监听可以用v-on指令:
 <button v-on:click="counter += 1">增加 1</button>
  • 我们需要使用一个方法来调用 JavaScript 方法,v-on 可以接收一个定义的方法来调用
 <button v-on:click="greet">Greet</button> methods: {    greet: function (event) {      // `this` 在方法里指当前 Vue 实例      alert('Hello ' + this.name + '!')      // `event` 是原生 DOM 事件      if (event) {          alert(event.target.tagName)      }    }  }
  • 除了直接绑定到一个方法,也可以用内联 JavaScript 语句:
<button v-on:click="say('hi')">Say hi</button> methods: {    say: function (message) {      alert(message)    }  }

本文为企业推广,本网站不做任何建议,仅提供参考,作为信息展示!

推荐阅读:叶紫网

网友评论
请登录后进行评论| 0条评论

请文明发言,还可以输入140

您的评论已经发表成功,请等候审核

小提示:您要为您发表的言论后果负责,请各位遵守法纪注意语言文明

回到首页 回到顶部
河南在线 关于我们| 联系我们| 招聘信息| 老版地图| 网站地图
免责声明:河南在线所有文字、图片、视频、音频等资料均来自互联网,不代表本站赞同其观点,本站亦不为其版权负责。相关作品的原创性、文中陈述文字以及内容数据庞杂本站无法一一核实,如果您发现本网站上有侵犯您的合法权益的内容,请联系我们,本网站将立即予以删除!
Copyright © 2012-2019 http://www.hnzxwz.cn, All rights reserved.