Vue进阶(八十八):vue中的.sync修饰符用法及原理详解

本文主要是介绍Vue进阶(八十八):vue中的.sync修饰符用法及原理详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

子组件使用this.$emit()向父组件传值时,首先必须在父组件中引用子组件,然后实现传值。

第一步 在父组件中引入子组件

引入
使用import引入组件

import indexImportOrder from './components/indexImportOrder'

声明

 //定义组件components:{indexImportOrder,},

使用

<indexImportOrder ref="indexImportOrder"/>

第二步 子组件向父组件传值

在子组件中需要向父组件传值处,使用this.$emit("function",param); 其中,function与父组件中@后的函数名一致,param为需要传递参数。

在父组件引用子组件处,添加函数v-on:function="function1"; 其中,function为子组件中传递的函数名称保持一致,function1为父组件定义函数(用于接收子组件传值并进行相应数据处理)
v-on: 可用 @ 代替 。@function="function1"@v-on:的简写。

<indexImportOrder ref="indexImportOrder" @closeMain="closeMainPar"/>

val为接收的子组件参数,

closeMainPar(val){this.flag = val;
},

vue中我们经常会用v-bind(缩写为:)给子组件传入参数。或者我们会给子组件传入一个函数,子组件通过调用传入的函数来改变父组件的状态。
例如:

//父组件给子组件传入一个函数<MyFooter :age="age" @setAge="(res)=> age = res"></MyFooter>//子组件通过调用这个函数来实现修改父组件的状态。mounted () {console.log(this.$emit('setAge',1234567));}

这时子组件触发了父组件的修改函数,使父组件的age修改成了1234567.

这种情况比较常见切写法比较复杂。于是我们引出今天的主角 .sync(数据双向绑定)

这时我们可以直接这样写

//父组件将age传给子组件并使用.sync修饰符,数据双向绑定会把子组件的age属性同步会父组件的age属性。
<MyFooter :age.sync="age">
</MyFooter>
//子组件触发事件mounted () {console.log(this.$emit('update:age',1234567));}

这里注意我们的事件名称被换成了update:age

  • update:是被固定的,也就是vue为我们约定好的名称部分。
  • age是我们要修改的状态名称,是我们手动配置的,与传入的状态名字对应起来。

这样就完成了,是不是感觉简单了很多。

注意事项:
这里我们必须在事件执行名称前加上update:的前缀才能正确触发事件。

这篇关于Vue进阶(八十八):vue中的.sync修饰符用法及原理详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/715445

相关文章

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

C语言中%zu的用法解读

《C语言中%zu的用法解读》size_t是无符号整数类型,用于表示对象大小或内存操作结果,%zu是C99标准中专为size_t设计的printf占位符,避免因类型不匹配导致错误,使用%u或%d可能引发... 目录size_t 类型与 %zu 占位符%zu 的用途替代占位符的风险兼容性说明其他相关占位符验证示

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

Python标准库之数据压缩和存档的应用详解

《Python标准库之数据压缩和存档的应用详解》在数据处理与存储领域,压缩和存档是提升效率的关键技术,Python标准库提供了一套完整的工具链,下面小编就来和大家简单介绍一下吧... 目录一、核心模块架构与设计哲学二、关键模块深度解析1.tarfile:专业级归档工具2.zipfile:跨平台归档首选3.

全面解析Golang 中的 Gorilla CORS 中间件正确用法

《全面解析Golang中的GorillaCORS中间件正确用法》Golang中使用gorilla/mux路由器配合rs/cors中间件库可以优雅地解决这个问题,然而,很多人刚开始使用时会遇到配... 目录如何让 golang 中的 Gorilla CORS 中间件正确工作一、基础依赖二、错误用法(很多人一开

idea的终端(Terminal)cmd的命令换成linux的命令详解

《idea的终端(Terminal)cmd的命令换成linux的命令详解》本文介绍IDEA配置Git的步骤:安装Git、修改终端设置并重启IDEA,强调顺序,作为个人经验分享,希望提供参考并支持脚本之... 目录一编程、设置前二、前置条件三、android设置四、设置后总结一、php设置前二、前置条件

Java Stream流之GroupBy的用法及应用场景

《JavaStream流之GroupBy的用法及应用场景》本教程将详细介绍如何在Java中使用Stream流的groupby方法,包括基本用法和一些常见的实际应用场景,感兴趣的朋友一起看看吧... 目录Java Stream流之GroupBy的用法1. 前言2. 基础概念什么是 GroupBy?Stream

python中列表应用和扩展性实用详解

《python中列表应用和扩展性实用详解》文章介绍了Python列表的核心特性:有序数据集合,用[]定义,元素类型可不同,支持迭代、循环、切片,可执行增删改查、排序、推导式及嵌套操作,是常用的数据处理... 目录1、列表定义2、格式3、列表是可迭代对象4、列表的常见操作总结1、列表定义是处理一组有序项目的

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

C++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3