IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue v-model与.sync详解 -> 正文阅读

[JavaScript知识库]vue v-model与.sync详解

用过vue的小伙伴应该都知道,使用表单绑定值的时候,我们通常会用到一个?v-model 指令,它可以在表单以及元素上面创建双向数据绑定。

1、但是其实 v-model 是一个语法糖,它真的是实现是这样的:

<input v-model="val" type="text">
// 本质:
<input :value="val"  @input="val=$event.target.value" />

要理解这行代码,首先你要知道 input 元素本身有个input 事件,这是 HTML5 新增加的,类似 onchange ,每当输入框内容发生变化,就会触发 input 事件,把最新的value值传给传递给val ,完成双向数据绑定的效果 。

?2、相信用 v-mode 绑定绑定表单,大家都非常熟悉,但是 v-model 还有一个作用,可以用于父子组件之间数据的双向绑定。

//  parent组件,也就是我们的父组件
<template>
  <div>
    <son v-model="name"/>
  </div>
</template>
<script>
import son from './son.vue'  
export default {
  components: {son},
  data() {
    return {
      name:"旺柴"
    }
  }
}
</script>
// son 组件,也就是我们的子组件
<template>
  <div>
    {{ value }} 
    // 父组件绑定的v-model的值
  </div>
</template>
<script>
export default {
// 这里必须用value名称,换成其他的无效
  props: {
    value: {
      type:String,
      required: true
    }
  }
}
</script>

但是有一点需要注意:由于vue是单向数据流的,所以我们不能子组件中直接修改value值,根据我们的经验,一般我们会通过在子组件中使用$emit('自定义事件名',值)的方法将值传入父组件。

但是这里不能这样做,因为是使用v-model绑定的值,我们要用@input事件进行修改

// 子组件中通过 $emit()方法,绑定一个input方法,注意,只能是input
<template>
  <div>
    <div @click="$emit('input',value+'汪汪汪')"></div>
  </div>
</template>

成功修改value的值!撒花~

3、.sync修饰符作用

.sync修饰符可以实现子组件与父组件的双向绑定,并且可以实现子组件同步修改父组件的值。

不使用.sync的情况下是:?

// 父组件:
<template>
  <div>
    <my-son :name="name" @changeName='changeName' />
  </div>
</template>
<script>
import mySon from "./components/mySon.vue"
export default {
  components: {
    mySon
  },
  data () {
    return {
      name: '旺柴'
    };
  },
  methods: {
    changeName (value) {
      this.name = this.name + value
    }
  },
}
</script>


// 子组件
<template>
  <div @click='changeName'>
    {{name}}
  </div>
</template>

<script>

export default {
  props: {
    name: {
      type: String,
      default: ''
    }
  },
  methods: {
    changeName () {
      this.$emit('changeName', '汪汪汪')
    }
  },
}
</script>

使用 .async。

// 父组件
<template>
  <div>
    <my-son :name.sync="name" />
  </div>
</template>
<script>
import mySon from "./components/mySon.vue"
export default {
  components: {
    mySon
  },
  data () {
    return {
      name: '旺柴'
    };
  },
}
</script>

// 子组件
<template>
  <div @click='changeName'>
    {{name}}
  </div>
</template>
<script>
export default {
  props: {
    name: {
      type: String,
      default: ''
    }
  },
  methods: {
    changeName () {
      this.$emit('update:name', this.name + '汪汪汪')
    }
  },
}
</script>

区别在于往回传值的时候. async 的?$emit?所调用的事件名必须是update:属性名。

4、.sync与v-model区别:
相同点:都是语法糖,都可以实现父子组件中的数据的双向通信。
区别点:
格式不同。 v-model=“num”, :num.sync=“num”
v-model: @input + value
:num.sync: @update:num
v-model只能用一次;.sync可以有多个。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-09-21 00:19:29  更:2022-09-21 00:23:26 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 14:59:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码