Vue之基本语法

作者: Ping开源 | 来源:发表于2021-04-09 12:12 被阅读0次

二、基本语法

目录:v-bind、v-if、v-else-if、v-else、v-for、v-on

1.v-bind

已经成功创建了第一个Vue应用。看起来这跟渲染一个字符串模板非常类似,但是Vue在背后做了大量的工作。现在数据和DOM已经被建立了关联,所有东西都是响应式的。在控制台操作对象属性,界面可以实时更新。
可以使用v-bind来绑定元素特性。

<!DOCTYPE html>
<html xmlns:v-bind="http://www.w3.org/1999/xhtml">
<head>
  <meta charset="UTF-8">
  <title>v-bind</title>
  <script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.js"></script>
</head>
<body>
<div id="app">
  <span v-bind:title="message">
    鼠标悬停几秒钟查看此处动态绑定的时间信息
  </span>
</div>
<script type="text/javascript">
  var app = new Vue({
    el: '#app',
    data: {
      message: '页面加载时间:' + new Date().toLocaleString()
    }
  })
</script>
</body>
</html>

像v-bind等被成为指令。指令带有前缀v-,以表示它们是Vue提供的特殊特性。它们会在渲染的DOM上应用特殊的响应式行为。在这里该指令的意思是:将这个元素节点的title特性和Vue实例的message属性保持一致。
如果再次打开浏览器的JavaScript控制台,输入app.message='新消息',就会再一次看到这个绑定了title特性的HTML已经进行了更新。

2.v-if,v-else

条件判断语句

  • v-if
  • v-else
<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <title>v-if,v-else</title>
  <script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.js"></script>
</head>
<body>
<div id="vue">
  <h1 v-if="ok">YES</h1>
  <h1 v-else>NO</h1>
</div>
<script type="text/javascript">
  var vm = new Vue({
    el: '#vue',
    data: {
      ok: true
    }
  });
</script>
</body>
</html>

测试:①在浏览器上运行,打开控制台。
②在控制台输入vm.ok=false,然后回车,会发现浏览器中显示的内容会直接变成NO。
注:使用v-*属性绑定数据是不需要双花括号包裹的。

3.v-else-if

  • v-if
  • v-else-if
  • v-else
<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <title>v-else-if</title>
  <script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.js"></script>
</head>
<body>
<div id="vue">
  <h2 v-if="type === 'A' ">A</h2>
  <h2 v-else-if="type === 'B' ">B</h2>
  <h2 v-else-if="type === 'C' ">C</h2>
  <h2 v-else>who</h2>
</div>
<script type="text/javascript">
  var vm = new Vue({
    el: '#vue',
    data: {
      type: 'A'
    }
  });
</script>
</body>
</html>

测试:观察在控制台分别输入vm.type='B'、'C'、'D'的变化。
注:===三个等号在JS中表示绝对等于(就是数据与类型都要相等)。

4.v-for

格式说明

<div id="vue">
  <li v-for="item in items">
    {{ item.message }}
  </li>
</div>

注:items是数组,item是数组元素迭代的别名。之后学习的Thymeleaf模板引擎的语法与之十分的相似。

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <title>v-for</title>
  <script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.js"></script>
</head>
<body>
<div id="vue">
  <li v-for="item in items">
    {{ item.message }}
  </li>
</div>
<script type="text/javascript">
  var vm = new Vue({
    el: '#vue',
    data: {
      //items数组
      items: [
        {message: '前端'},
        {message: 'Vue'},
        {message: 'Java'}
      ]
    }
  });
</script>
</body>
</html>

测试:在控制台输入vm.items.push({message: '运维'}),尝试追加一条数据,会发现浏览器中显示的内容会增加一条 运维。

5.v-on

监听事件
事件有Vue的事件和前端页面本身的一些事件。下面的click是Vue的事件,可以绑定到Vue中的methods中的方法事件。

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <title>v-on</title>
  <script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.js"></script>
</head>
<body>
<div id="vue">
  <!--在这里使用了v-on绑定了click事件,并指定了名为sayHi的方法-->
  <button v-on:click="sayHi">点我</button>
</div>
<script type="text/javascript">
  var vm = new Vue({
    el: '#vue',
    data: {
      message: 'Hello World'
    },
    //方法必须定义在Vue实例的methods对象中
    methods: {
      sayHi: function (e) {
        //this在方法里指向Vue实例
        alert(this.message);
      }
    }
  });
</script>
</body>
</html>

相关文章

  • Vue之基本语法

    二、基本语法 目录:v-bind、v-if、v-else-if、v-else、v-for、v-on 1.v-bin...

  • Vue基本语法

    一、Vue介绍 1、Vue.js 是什么 Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面...

  • vue基本语法

    模板语法 文本 使用{{}}进行数据绑定 原始html 属性 使用表达式 指令 指令带有v前缀的属性 参数 动态参...

  • Vue基本语法

    一、Mustache 如何将data中的文本数据,插入到HTML中呢?我们已经学习过了,可以通过Mustache语...

  • vue基本语法

    快速入门 v-on: click 事件绑定 v-on:keydom 键盘绑定 v-on:mouseover 获取焦...

  • VUE基本语法

    一、template 二、script 三、style

  • vue基本语法

    一、推荐插件 Live Server 插件,保存后自动刷新浏览器 open in browser, 可以将htm...

  • 《二》、Vue核心——基本使用

    一、Vue的基本使用 1、编码 2、理解 Vue 的 MVVM 3、模板语法 (1)、模板语法的理解  Ⅰ、动态的...

  • 01Vue基本使用与模板语法

    Vue基本使用与模板语法 一. 基本使用 Hello World快速入门 二. 模板语法 指令 概述 指令的本质就...

  • Swift基本语法之函数

    Swift基本语法之初体验-常量变量-数据类型 Swift基本语法之逻辑分支 Swift基本语法之循环 Swift...

网友评论

    本文标题:Vue之基本语法

    本文链接:https://www.haomeiwen.com/subject/fvnpkltx.html