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知识库 -> v-model在组件封装中的妙用-含vue2和vue3的区别 -> 正文阅读

[JavaScript知识库]v-model在组件封装中的妙用-含vue2和vue3的区别

在开发中我们通常在表单元素上使用v-model来实现数据的双向绑定。其实v-model只是语法糖,是v-bind和v-on的缩写

官方解释:

// 以下两种是等价的
<input v-model="searchText">
<input
  v-bind:value="searchText"
  v-on:input="searchText = $event.target.value"
>

基于以上的理论只是我们来展开说明Vue和和Vue3在组件上使用v-model的区别

Vue2

  1. 写法一

    <template>
      <div>
        <child v-model="test" />
        <p>父组件:{{ test }}</p>
        <button @click="fn1">父组件</button>
      </div>
    </template>
    
    <script>
    //父组件
    import child from './child.vue'
    export default {
      components: { child },
      name: 'Home',
      data() {
        return {
          test: ''
        }
      },
      methods: {
        fn1() {
          this.test += 1
        }
      }
    }
    </script>
    //------------------------------------------------------
    <template>
      <div>
        <p>子组件普通元素的值{{ msg }}</p>
        <button @click="fn">子组件普通元素的按钮</button>
      </div>
    </template>
    
    <script>
    export default {
        //子组件
      // props是对象的时候,里面的属性值不能用基本类型了
      /**
       * model 表示了v-model使用的属性和事件名称
       * 一个组件上的v-model默认利用名为value的prop和名为input的事件
       */
      model: {
        prop: 'msg', // v-bind 的属性
        event: 'cc' // v-on的属性
      },
      props: {
        msg: {}
      },
      methods: {
        fn() {
          this.$emit('cc', this.msg + 2)
        }
      }
    }
    </script>
    
    <style></style>
    
    
    
  2. 写法二:

<template>
  <div>
    <child-input v-model="content" />
    <p>父组件input的值:{{ content }}</p>
  </div>
</template>

<script>
 //父组件
import childInput from './childInput.vue'
export default {
  components: { childInput },
  name: 'Home',
  data() {
    return {
      content: ''
    }
  }
}
</script>
//-----------
<template>
  <div>
    <input v-model="editContent" />
  </div>
</template>

<script>
export default {
 //子组件
  props: {
    // v-mode默认时使用名称为value的prop
    value: String
  },
  data() {
    return {
      content: ''
    }
  },
  computed: {
    editContent: {
      get() {
        return this.value
      },
      set(newVal) {
        this.$emit('input', newVal)//必须使用input发送数据,父组件的v-model才会接收到。默认的是input
      }
    }
  }
}
</script>

<style></style>


vue3

vue3和vue2是不兼容的:vue3的语法糖原里是:自定义组件上的 v-model 相当于传递了 modelValue prop 并接收抛出的 update:modelValue 事件:

写法:

<template>
  <div class="home">
    <child v-model="pContent" />
    <p>父组件的值{{ pContent }}</p>
  </div>
</template>

<script setup>
import { ref } from 'vue'
import child from './child.vue'
const pContent = ref('')
</script>
//-----------------------------------
<template>
  <div>
    <input v-model="value" />
  </div>
</template>

<script setup>
//其实defineProps和 defineEmits 是不需要导的,eslint会检查就写上了
import { defineProps, defineEmits, computed } from 'vue'
const props = defineProps(['modelValue'])
const emits = defineEmits(['update:modelValue'])
const value = computed({
  get: () => props.modelValue,
  set: (val) => {
    emits('update:modelValue', val)
  }
})
</script>

<style lang="less" scoped></style>

具体差别详见官方地址: v-model

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-11 16:21:48  更:2022-05-11 16:22:29 
 
开发: 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 5:51:01-

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