关注我

    我的微信
在线咨询 x
在线咨询
有什么可以帮到你
点击咨询

Vue学习笔记(4) —— v-model指令,双向数据绑定

简介v-model指令的本质是: 它负责监听用户的输入事件,从而更新数据,并对一些极端场景进行一些特殊处理,从而实现数据的双向绑定。

Vue官方对应文档:v-model指令双向绑定


v-model指令的本质是: 它负责监听用户的输入事件,从而更新数据,并对一些极端场景进行一些特殊处理,从而实现数据的双向绑定。同时,v-model会忽略所有表单元素的value、checked、selected特性的初始值,它总是将Vue实例中的数据作为数据来源。 然后当输入事件发生时,实时更新vue实例中的数据。


Vue的核心特性之一是双向绑定,vue的响应式原理是实现了数据->视图,接下来我们要学习 视图->数据的原理。


v-model指令,限制在表单元素<input>、<select>、<textarea> 和 components中使用,修饰符.lazy(取代 input 监听 change?事件)、.number(输入字符串转为有效的数字)、.trim(输入首尾空格过滤)。它其实是一个语法糖,接下来我们就来分析v-model的实现原理。



一、双向绑定示例代码


<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>v-model指令,双向数据绑定</title>
  <script src="https://www.whmblog.cn/static/js/lib/vue-2.4.0.js"></script>
</head>

<body>
<div id="app">
  <h4>{{ msg }}</h4>

  <!-- v-bind 只能实现数据的单向绑定,从 M 自动绑定到 V, 无法实现数据的双向绑定  -->
  <h1>单向绑定</h1>
  <input type="text" v-bind:value="msg" style="width:100%;">

  <!-- 使用  v-model 指令,可以实现 表单元素和 Model 中数据的双向数据绑定 -->
  <!-- 注意: v-model 只能运用在 表单元素中 -->
  <!-- input(radio, text, address, email....)   select    checkbox   textarea   -->
  <h1>双向绑定</h1>
  <input type="text" style="width:100%;" v-model="msg">
</div>

<script>
  // 创建 Vue 实例,得到 ViewModel
  var vm = new Vue({
    el: '#app',
    data: {
      msg: '大家都是好学生,爱敲代码,爱学习,爱思考,简直是完美,没瑕疵!'
    },
    methods: {
    }
  });
</script>
</body>

</html>



二、实现一个简单计算器功能



<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>简易的计算器</title>
  <script src="https://www.whmblog.cn/static/js/lib/vue-2.4.0.js"></script>
</head>

<body>
  <div id="app">
    <input type="number" v-model="n1">

    <select v-model="opt">
      <option value="+">+</option>
      <option value="-">-</option>
      <option value="*">*</option>
      <option value="/">/</option>
    </select>

    <input type="number" v-model="n2">

    <input type="button" value="=" @click="calc">

    <input type="number" v-model="result">
  </div>

  <script>
    // 创建 Vue 实例,得到 ViewModel
    var vm = new Vue({
      el: '#app',
      data: {
        n1: 0,
        n2: 0,
        result: 0,
        opt: '+'
      },
      methods: {
        calc() { // 计算器算数的方法  
          // 逻辑:
          /* switch (this.opt) {
            case '+':
              this.result = parseInt(this.n1) + parseInt(this.n2)
              break;
            case '-':
              this.result = parseInt(this.n1) - parseInt(this.n2)
              break;
            case '*':
              this.result = parseInt(this.n1) * parseInt(this.n2)
              break;
            case '/':
              this.result = parseInt(this.n1) / parseInt(this.n2)
              break;
          } */

          // 注意:这是投机取巧的方式,正式开发中,尽量少用
          var codeStr = 'parseFloat(this.n1) ' + this.opt + ' parseFloat(this.n2)'
          this.result = eval(codeStr)
        }
      }
    });
  </script>
</body>

</html>