vue 自定义组件 v-model双向绑定、 父子组件同步通信

父子组件通信,都是单项的,很多时候需要双向通信。方法如下:

  1、父组件使用:msg.sync="aa"  子组件使用$emit(‘update:msg‘, ‘msg改变后的值xxx‘)

  2、父组件传值直接传对象,子组件收到对象后可随意改变对象的属性,但不能改变对象本身。

  3、父组件使用: v-model

  第一种曾经被废除过,由于维护成本的原因被删掉,但经过证实,确实有存在的意义,又被加上。

  第一种:

父组件:
    <template>
  <div>
    <aa class="abc" :snycTest.sync="test" ></aa>
      {{‘外面的值:‘ + test}}
    <button @click="fn">
      外面改变里面
    </button>

  </div>
</template>

<script>
import aa from ‘./test.vue‘
  export default {
    data () {
      return {
        test: ‘‘
      }
    },
    methods: {
      fn () {
        this.test += 1
      }
    },
    components:{
      aa
    }
  }
</script>

  

子组件:
 <template>
  <div>
    <ul>
      <li>{{‘里面的值:‘+ snycTest}}</li>
      <button @click="fn2">里面改变外面</button>
    </ul>
  </div>
</template>

<script>
  export default {
    props: {
      snycTest: ‘‘
    },
    methods: {
      fn2 () {
        this.$emit(‘update:snycTest‘, this.snycTest+1) //这儿是关键 update:snycTest 自定义事件会告诉父组件将父组件的 test值改为this.snycTest+1,并传回给子组件。
} } } </script>

v-model写法一:

父组件:
 <template>
  <div>
    <aa class="abc" v-model="test" ></aa>  // 组件中使用v-model
      {{‘外面的值:‘ + test}} // 这儿试验test与内部msg值为双向绑定关系
    <button @click="fn">
      外面改变里面
    </button>

  </div>
</template>

<script>
import aa from ‘./test.vue‘
  export default {
    data () {
      return {
        test: ‘‘
      }
    },
    methods: {
      fn () {
        this.test += 1
      }
    },
    components:{
      aa
    }
  }
</script>
子组件写法一:
<template>
  <div>
    <ul>
      <li>{{‘里面的值:‘+ msg}}</li>
      <button @click="fn2">里面改变外面</button>
    </ul>
  </div>
</template>

<script>
  export default {
    model: {    // 使用model, 这儿2个属性,prop属性说,我要将msg作为该组件被使用时(此处为aa组件被父组件调用)v-model能取到的值,event说,我emit ‘cc’ 的时候,参数的值就是父组件v-model收到的值。
      prop: ‘msg‘,
      event: ‘cc‘
    },
    props: {
      msg: ‘‘
    },
    methods: {
      fn2 () {
        this.$emit(‘cc‘, this.msg+2)
      }
    }
  }
</script> 

v-model写法二

  父组件 <aa class="abc" v-model=‘test‘ value="what"></aa> 父组件必须传value属性,它的值没有任何意义,但必须要传。这儿需要注意,当组件种有v-model时候,value的传值不会被渲染,所以非必要不要使用value传值。

子组件
<template>
 <div>
    <ul>
      <li>{{‘里面的值:‘+ value}}</li> // 组件使用时有v-model属性,value初始传的‘what’ 不会被渲染,而是v-model绑定的test值被渲染,这儿value会被重新赋值为v-model绑定的test的值。
      <button @click="fn2">里面改变外面</button>
    </ul>
  </div>
</template>

<script>
  export default {
    props: {
      value: ‘‘,
    },

    methods: {
      fn2 () {
        this.$emit(‘input‘, this.value+2) // 这儿必须用input 发送数据,发送的数据会被父级v-model=“test”接受到,再被value=test传回来。
      }
    }
  }

一般双向绑定用v-model写法一。

    

时间: 2024-10-12 06:37:45

vue 自定义组件 v-model双向绑定、 父子组件同步通信的相关文章

Vue的双向绑定以及组件的自定义事件

什么是双向绑定 所谓的双向绑定是指数据发生变化时,视图会同步发生变化,而当视图发生变化时,数据也会同步变化. Vue中怎么实现双向绑定 在Vue中,我们通过v-model来创建双向绑定. 我们继续用todolist和todoitme组件来示例双向绑定 在App.vue的data中增加一个message. data(){ return{ message:"hello world", list: [ { title: "新课程1", del: false }, { ti

第四节:Vue表单标签和组件的基本用法,父子组件间的通信

vue表单标签和组件的基本用法,父子组件间的通信,直接看例子吧. <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <script src="vue.js"></script> </head> <body> <div id="app"&

自定义父子组件的数据双向绑定实现

数据结构: 流程分析: 新建时,需要在提交表单时获取到子组件的child数据,一般情况下,在提交时,利用this.parent.child=this.$refs.child.child,将child的数据赋值到parent中 修改时,需要从父组件把child对象传递给子组件,在获取parent的信息后,调用this.$refs.child.setData(this.parent.child)将数据传递到子组件中 问题:什么时候调用?(第一次尝试,新建时在提交表单时去拿child的数据,修改时在m

angularjs1.x版本,父子组件之间的双向绑定

今天遇到了一个angularjs的坑, ng-repeat和ng-if会改变他所包含的html中绑定变量的作用域. angularjs自定义指令,可以定义四种变量,通过 =,@,&双向绑定,单项绑定,回调函数绑定 如果在ng-repeat 或者ng-if的包含的内容中,调用其它自定义组件,并传输双向绑定的变量时,需要查看当前作用域时什么,需要$parent返回到$scope作用域才能拿到需要绑定的变量 原文地址:https://www.cnblogs.com/HappyYawen/p/88681

使用 v-model 实现 双向绑定.(子组件和父组件.)

父子组件通信,都是单项的,很多时候需要双向通信.方法如下: 1.父组件使用:msg.sync="aa"  子组件使用$emit('update:msg', 'msg改变后的值xxx') 2.父组件传值直接传对象,子组件收到对象后可随意改变对象的属性,但不能改变对象本身. 3.父组件使用: v-model 第一种曾经被废除过,由于维护成本的原因被删掉,但经过证实,确实有存在的意义,又被加上. 第一种: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 1

谈谈对vue的认识2:双向绑定 v-model

1:v-model指令 数据的双向绑定 双向绑定是说我们不仅仅可以通过数据(M)的改变去影响视图(V),还是当视图的内容改变(V)去影响模型中的数据(M) 通常来说双绑定应用在表单中比较多 指令: vue对html元素拓展是一些属性名称(自定义属性名称) Vue指令有个特点,都是以v-开头的 V-model,它提供了一个js环境,在他的属性之中我们可以使用js(vue实例化对象)中的变量,将表单元素的值与vue实例化对象中是数据属性同步,实现视图到模型中的数据的一个绑定,因此在表单元素上添加了v

vue跳转,v-model 双向绑定,-vuex的使用cookie:,视频第三方播放

-vue中路由携带参数跳转 -跳转的时候: <router-link :to="{'name':'coursedetail','params':{'id':course.id}}">课程详情</router-link> -在下一个组件中取值: course_id: this.$route.params.id, 今日内容: -课程列表接口 -写一个序列化类Courseserializers -在视图类中: def get_list(self, request, *

关于vue的计算属性以及双向绑定的原理理解(vue2.x)以及vue3.0

vue的计算属性: 1.什么是计算属性? 计算属性的目的是用于对数据进行简单运算的,若在模板中放过多的计算逻辑会导致模板难以维护. 计算属性是基于它们的依赖进行缓存的.计算属性只有在它的相关依赖发生改变时才会重新求值. 2.计算属性如何使用? 1.在一个计算属性里可以完成各种复杂的逻辑,包括运算.函数调用等,只要最终返回一个结果就可以. computed: { reverseText: function(){ return app1.text.split('').reverse().join('

vue.js学习笔记(4)— 父子组件之间通信的第一种方式 props 和 $emit

我们知道,vue组件中,父组件把数组传递给子组件的话,通常是使用props传递,而vue规定,prop是只能单向下行传递的,那么子组件要怎么才能实现数据的向上传递呢,这里引述一个概念:"父子组件的关系:prop向下传递,事件向上传递",上一篇文章当中,关于数据向上传递用到的事件方法 $emit() 也进行了详细的说明,不懂的童鞋可以翻回去看一下.下面就是今天要说的父子组件相互通信的问题,点击效果依次如下: 代码如下: <!DOCTYPE html> <html>

VUE 入坑系列 一 双向绑定

html代码 <div id="app"> <p>{{message}}</p> <span>message1</span> <input v-model="message"> <span>message2</span> <input v-model="message"> </div> javascript代码 var vm =