美文网首页
Vue--data,props,$emit,v-model

Vue--data,props,$emit,v-model

作者: kiterumer | 来源:发表于2019-05-09 16:56 被阅读0次

data

Vue 实例的数据对象。Vue 将会递归将 data 的属性转换为 getter/setter,从而让 data 的属性能够响应数据变化。对象必须是纯粹的对象 (含有零个或多个的 key/value 对)。

实例创建之后,可以通过vm.$data访问原始数据对象。Vue实例也代理了对象上所有的属性,因此访问vm.a等价于vm.$data.a

当一个组件被定义,data 必须声明为返回一个初始数据对象的函数,因为组件可能被用来创建多个实例。如果 data 仍然是一个纯粹的对象,则所有的实例将共享引用同一个数据对象!通过提供 data 函数,每次创建一个新实例后,我们能够调用 data 函数,从而返回初始数据的一个全新副本数据对象。
可以想象原型。

// Vue.extend() 中 data 必须是函数
var Component = Vue.extend({
  data: function () {
    return { a: 1 }
  }
/*
等价于 data(){
  return { a: 1 }
}
*/
})

注意,如果你为 data 属性使用了箭头函数,则 this 不会指向这个组件的实例,不过你仍然可以将其实例作为函数的第一个参数来访问。

data: vm => ({ a: vm.myProp })  //可以访问vm的属性
data: () => { this.a }  //this并不指向vm

props

使用props传递数据作用域是孤立的,它是父组件通过模板传递而来,想接收到父组件传来的数据,需要通过props选项来进行接收。
子组件需要显示的声明接收父组件传递来的数据的数量,类型,初始值。
简单的接收可以通过数组的形式来进行接收。
父组件通过在子组件模板中用v-bind:来传递子组件中需要接收的数据

父组件
<template>
   <div>
      <demo :msg='msgData' :math = 'mathData' ></demo>
   </div>
</template>
<script>
 export default {
     data () {
       return  {
          msgData:'从父组件接收来的数据',
          mathData : 2
       }
     },
     components : {
       Demo
     }
   }
</script>

子组件
export default {
  name: 'demo',
  props: [ 'msg' , 'math']
}

语法::msg = msgData

  • msg必须要与子组件的props同名
  • msgData则是父组件中想子组件传递的数据,一个变量,中转作用

在 data 选项中,当前实例(当前组件中改动)可以任意改变data选项里的数据,Vue传递数据时是基于数据单向流动,子组件不能改变当前实例中的 props 任何属性,需要通知父组件改变相应的值,重新改变。
类似水会从高向地处流,要想改变下游的水,需要从源头改变。

on,emit,v-on

每个 Vue 实例都实现了事件接口:

  • 使用$on(eventName)监听事件 vm.$emit( event, […args] )
  • 使用$emit(eventName)触发事件 vm.$on( event, callback )
    $emit的(eventName)和$on的(eventName)是一一对应的。

$emit$on 必须都在实例上进行触发和监听。

父组件可以在使用子组件的引入模板直接用 v-on 来监听子组件($emit)触发的事件。

v-model(语法糖)

<input v-model="something">

不过是以下示例的语法糖:

<input
  v-bind:value="something"
  v-on:input="something = $event.target.value">

既然在元素上能进行双向绑定,那在组件中进行双向绑定又如何实现,原理其实都是一样的,只是应用在自定义的组件上时,拿的并不是$event.target.value,因为我此时不作用在 Input 输入框上。

<custom-input
  v-bind:value="something"
  v-on:input="something = arguments[0]">
</custom-input>

通过以上简写,通过自定事件让 v-model 进行一个父子组件双向绑定的话。
v-bind:value='something' 此时 value 是作为子组件接收的 props
接收的只能是 value 吗?必须是,因为 v-model 是基于 Input 输入框定制的,其中value 值是为 Input 内部定制的
此时作用在组件上时,v-on 监听的语法糖也会有所改动,监听的并不是$event.target.value,而是回调函数中的第一个参数

checkbox 和 radio 原理

<input type="checkbox" :checked="status" @change="status = $event.target.checked" />
 
<input type="radio" :checked="status" @change="status = $event.target.checked" />

通过绑定 checked 属性,同样的监听的是 change 事件,无论是 checkbox 还是 radio 在操作的时候都会隐式自动触发一个 change 事件,跟 Input 通过 value 值,Input 触发事件原理绑定是一样的。

相关文章

  • Vue--data,props,$emit,v-model

    data Vue 实例的数据对象。Vue 将会递归将 data 的属性转换为 getter/setter,从而让 ...

  • vueuse的用法

    useVModel v-model 绑定的简写,props + emit -> ref 先看v-model的写法 ...

  • Vue3 的七种组件通信方式

    七种组件通信方式: props emit v-model refs provide/inject eventBus...

  • Vue基础

    如何实现组件通信 父子通信 props & emit v-model sync children 兄弟通信 thi...

  • Vue核心知识-Vue的组件之自定义双向绑定

    实现类似 v-model 的功能 实现数据双向绑定 在组件内,添加 props;组件修改数据时 emit 事件,并...

  • 简单的todo-list

    利用v-model双向数据绑定父组件向子组件传值用 props子组件向父组件传值用 $emit()

  • Vue组建通信的几种方法

    组件通信一 —— props和$emit props和$emit 父组件 向 子组件 传递数据 用 props 子...

  • vue--三种组件中之间的传值

    一、父子组件之间的传值----props/$emit 组件之间的传值,我们比较常用到的是props/$emit 1...

  • vue组件通信

    props/$emit:(常用) 比较常见的一种。父组件通过props向子组件传递数据,子组件通过$emit向父组...

  • vue组件的使用

    props和$emit 组件间通讯和自定义事件 父子通讯 props $emit兄弟组件或者隔代组件使用自定义事件...

网友评论

      本文标题:Vue--data,props,$emit,v-model

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