返回顶部
首页 > 资讯 > 前端开发 > JavaScript >前端框架Vue父子组件数据双向绑定的实现
  • 463
分享到

前端框架Vue父子组件数据双向绑定的实现

2024-04-02 19:04:59 463人浏览 泡泡鱼
摘要

目录一、父子组件单向传值1、父向子传值 2、子向父传值二、父子组件数据双向绑定实现思路: 父 向 子 组件传值:使用 props 属性。( props 是property[属性] 的

实现思路:

父 向 子 组件传值:使用 props 属性。( props property[属性] 的复数简写 )
子 向 父 组件传值:使用自定义事件。

一、父子组件单向传值

1、父向子传值

父向子组件传值,子组件接收到数据之后,保存到自己的变量中。


//父组件写法 
<cld :numP="num" ></cld> 
 
//子组件定义以及数据 
components:{ 
 cld:{ 
  template:'#child', 
  props:{ 
   numP:Number 
  }, 
 } 
} 
 
//子组件内容 
<template id="child"> 
 <div> 
  {{ numP }} 
 </div> 
</template> 


props 用于接收父组件传过来的值,props 的写法有很多种,具体如:


//方式1 :  直接接收数据 
props: [ 'numP' ] 
 
//方式2: 加类型限制 
props: [ 
 numP: Number 
 ]  
 
//方式3:添加默认值 
props: [ 
 numP: { 
  type:Number, 
  default:0 
  } 
]  
 
//方式4:是否必须值限制 
props: [ 
 numP: { 
  type:Number, 
  default:0, 
  require:true //添加必须值,不传此值会报错 
 } 
]  
 
//方式5:采用对象形式 
props: { 
 numP: { 
  type:Number, 
  default:0, 
 } 
} 

2、子向父传值

子向父组件传值,主要通过自定义事件进行传值,具体实例如下:


// 父组件内容 
<div> 
 子组件获取到的数据{{getNum}} 
 <cld :numb="num" @accept="getNumC"></cld> 
</div> 
 
//父组件方法 
methods:{ 
 getNumC(data){ 
  this.getNum = data //接收子组件传的数据 
 } 
}, 
//子组件定义 
components:{ 
 cld:{ 
  template:'#child', 
  data(){ 
   return{ 
    numC:1314 //子组件数据定义 
   } 
  }, 
  mounted(){ 
    this.$emit( 'accept' , this.numC ) // 触发自定义事件 
   } 
  } 
}, 

二、父子组件数据双向绑定

Vue 的数据都是单向流动的,而且 vue 中从来就没有任何的双向绑定,v-model 实现的双向绑定只是语法糖而已。

方式1:利用 watch 实现父子组件的数据双向绑定,具体实例如下:


<div id="app"> 
 数据<br>{{num}} 
 <input type="text" v-model="num"><br> 
 <cld :numb="num" @accept="getNumC"></cld> 
</div> 
//子组件内容 
<template id="child"> 
 <div> 
  数据<br>{{childNum}} 
  <input type="text" v-model="childNum" /> 
 </div> 
</template> 
 
  <!-- 父子组件通信 --> 
const app = new Vue({ 
 el:'#app', 
  data:{ 
   num:'520', 
   }, 
  methods:{ 
   getNumC(data){ 
    this.num = data 
   } 
  }, 
  components:{ 
   cld:{ 
    template:'#child', 
    props:{ 
     numb:String 
    }, 
   data(){ 
    return{ 
     childNum:0, 
    } 
   }, 
  watch:{ 
   numb:function(){ 
    this.childNum = this.numb 
   }, 
   childNum:function(){ 
    this.$emit('accept',this.childNum) 
    } 
   }, 
  mounted(){ 
   this.childNum = this.numb 
   } 
  } 
 }  
}) 


方式2:.sync 修饰符实现双向绑定

在vue 1.x 中的 .sync 修饰符所提供的功能。当一个子组件改变了一个带 .sync 的 prop 的值时,这个变化也会同步到父组件中所绑定的值。这很方便,但也会导致问题,因为它破坏了单向数据流。(数据自上而下流,事件自下而上走)


<cld :numb.sync="num" ></cld> 
//会扩展为: 
<cld  :numb="bar"  @update:numb=”val => bar = val”/> 


当组件需要更新 numb 的值时,需要触发更新事件:


this.$emit("update:numb", newValue ); 


使用具体实例如下:


// 父组件 
<Father :foo.sync="foo"></Father> 
 
//子组件 
props: ['foo'], 
data() { 
  return { 
   newFoo: this.foo; 
   } 
}, 
methods:{ 
 add:function(){ 
  this.newMsg=10; 
  this.$emit('update:foo',this.newFoo); 
 } 
} 

到此这篇关于前端框架Vue 父子组件数据双向绑定的文章就介绍到这了,更多相关Vue 父子组件数据双向绑定内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 前端框架Vue父子组件数据双向绑定的实现

本文链接: https://lsjlt.com/news/135537.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 前端框架Vue父子组件数据双向绑定的实现
    目录一、父子组件单向传值1、父向子传值 2、子向父传值二、父子组件数据双向绑定实现思路: 父 向 子 组件传值:使用 props 属性。( props 是property[属性] 的...
    99+
    2024-04-02
  • 浅析Vue3中通过v-model实现父子组件的双向数据绑定及利用computed简化父子组件双向绑定
    目录一、vue2 中 sync 修饰符的功能在 vue3 中如何呈现?1、sync 修饰符回顾2、sync 的语法糖功能在vue3中如何编写使用?二、如何通过v-model实现父子组...
    99+
    2022-12-12
    Vue3父子组件双向绑定 computed简化父子组件双向绑定 Vue3 v-model双向绑定
  • Vue父子组件数据双向绑定(父传子、子传父)及ref、$refs、is、:is的使用与区别
    既然有父传子那么肯定有子传父,有子传父肯定也有两者之间相互绑定 这里我们先看一下子传父的写法: 一、子传父:$emit() 看代码: <!DOCTYPE html> &l...
    99+
    2022-12-24
    Vue父子组件数据双向绑定 Vue组件父传子 Vue组件子传父 ref $refs is :is的使用与区别
  • vue3自定义组件之v-model实现父子组件双向绑定
    vue3 v-model父子组件双向绑定 vue3.x移除了vue2.x的model选项,自定义组件双向绑定不在使用以下方法: // vue2的v-model双向绑定方法 model...
    99+
    2022-11-13
    vue3自定义组件 vue3 v-model vue3父子组件 vue3双向绑定
  • vue实现双向数据绑定
    本文实例为大家分享了vue实现双向数据绑定的具体代码,供大家参考,具体内容如下 vue中数组与对象采用了不同的绑定方式 1.vue对象数据绑定 (1)数据侦测 在js中,我们使用Ob...
    99+
    2024-04-02
  • Vue3父子组件间通信和组件间双向绑定怎么实现
    本篇内容主要讲解“Vue3父子组件间通信和组件间双向绑定怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue3父子组件间通信和组件间双向绑定怎么实现”吧!假如确要修改,可以使用下面说的方...
    99+
    2023-07-06
  • Vue3父子组件间通信、组件间双向绑定的方法
    父子组件可通过事件 进行通信前面的笔记 —— 《Vue3 | 组件的定义及复用性、局部组件、全局组件、组件间传值及其校验、单项数据流、Non-props属性》,单向数据流的概念,即子组件无法修改来自父组件的数据字段,假如确要修改,可以使用下...
    99+
    2023-05-15
    Vue3
  • 前端MVVM框架中双向绑定的示例分析
    这篇文章主要介绍了前端MVVM框架中双向绑定的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。MVVM 框架基本概念在 MVVM 框架...
    99+
    2024-04-02
  • Vue组件间的双向绑定怎么实现
    这篇“Vue组件间的双向绑定怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue组件间的双向绑定怎么实现”文章吧。何...
    99+
    2023-07-05
  • vue实现简单数据双向绑定
    本文实例为大家分享了vue实现简单数据双向绑定的具体代码,供大家参考,具体内容如下 这里是简单的实现,有助于新手理解消化,当然vue要实现双向数据代理不可缺少,期待后续在更新 vue...
    99+
    2024-04-02
  • vue 数据双向绑定怎么实现
    这篇文章给大家分享的是有关vue 数据双向绑定怎么实现的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1. 前言实现简易版的数据双向绑定2. 代码实现2.1 目的分析本文要实现的效果如下图所示:本文用到的HTML和...
    99+
    2023-06-06
  • vue如何实现数据双向绑定
    Vue.js是一个流行的前端框架,它提供了多种方式来实现数据双向绑定。数据双向绑定是Vue.js最重要的特性之一,它使得开发者能够根据数据的变化自动更新视图,同时也能根据视图的变化自动更新数据。因此,Vue.js的数据双向绑定也成为前端面试...
    99+
    2023-05-14
  • vue双向数据绑定怎么实现
    Vue的双向数据绑定是通过v-model指令来实现的。1. v-model是Vue提供的一个指令,用于在表单元素上实现双向数据绑定。...
    99+
    2023-08-09
    vue
  • Vue数据的双向绑定如何实现
    本篇内容介绍了“Vue数据的双向绑定如何实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!实现组件双向数据绑定我们先来看看抛弃 .sync ...
    99+
    2023-07-04
  • vue自定义组件实现v-model双向绑定数据的实例代码
    项目中会遇到自定义公共组件供项目调用,正常情况可以使用 props定义参数接收父组件传的参数,然后通过子组件的$emits()方法回传数据给父组件。 类似如下: 父组件 <...
    99+
    2024-04-02
  • Vue 中怎么实现数据双向绑定
    本篇文章给大家分享的是有关 Vue 中怎么实现数据双向绑定,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。MVVM 架构的优点低耦合。视图(Vi...
    99+
    2024-04-02
  • vue中双向数据绑定怎么实现
    vue中双向数据绑定是通过数据劫持结合发布订阅模式的方式来实现的,其核心方法是Object.defineProperty()方法。实现双向数据绑定的示例:<!DOCTYPE html><html><h...
    99+
    2024-04-02
  • Vue中怎么实现数据双向绑定
    这篇文章主要介绍了Vue中怎么实现数据双向绑定的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue中怎么实现数据双向绑定文章都会有所收获,下面我们一起来看看吧。在我们使用vue的时候,当数据发生了改变,界面也会...
    99+
    2023-07-04
  • vue中自定义组件v-model双向绑定、 父子组件同步通信的写法有哪些
    这篇文章主要为大家展示了“vue中自定义组件v-model双向绑定、 父子组件同步通信的写法有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vue中自定义组...
    99+
    2024-04-02
  • Vue数据双向绑定的实现方式讲解
    目录前言一、input和textarea二、radio和CheckBox三、select四、双向绑定的修饰符前言 在web开发应用中,很多项目都会用到表格一列的组件进行数据的传输、获...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作