vue3.4 里面的新特性之v-model实践

vue3.4 里面的新特性

vue 的大版本版本已经升级到 3.4,就在写这篇文章的 30 分钟前,最近新版本是 3.4.20,可见 vue 团队的维护工作一直在持续的进行着...(手动点赞) 那么升级的后的新功能有哪些,这篇文章就来分析下 vue3.4.20 的几个最新功能

v-model

v-model 可以在组件上使用以实现双向绑定。

之前版本的写法

App.vue 组件

html 复制代码
<script setup>
  import Child from "./components/Child.vue";
  import { ref } from "vue";
  const tips = ref(undefined);
</script>

<template>
  <h3>parent:{{ tips }}</h3>
  <Child v-model="tips" />
</template>

<style scoped></style>

Child 组件

html 复制代码
<template>
  <div>
    <h2>{{ msg }}</h2>
    <input v-model="msg" />
  </div>
</template>

<script setup>
  import { ref } from "vue";
  const msg = ref("this is a msg");
</script>
<style scoped></style>

child组件里面的默认值如果要生效,父组件的tips要为undefined,为空null|''会覆盖默认值

  • 正常显示默认值
bash 复制代码
const tips = ref(undefined);
bash 复制代码
const tips = ref("");
  • 不显示默认值

### v3.4 版本的写法

xml 复制代码
从 Vue 3.4 开始,推荐的实现方式是使用 defineModel() 宏:

父组件的没变化,只要是子组件里面有所变化

Child 组件

```html
<template>
  <div>
    <h3>child props:{{ model }}</h3>
    <h3>{{ msg }}</h3>
    <input v-model="msg" />
  </div>
</template>
```

这里需要注意的,父组件的值不能为 null | '',不然子组件的默认值不会显示出来, 赋默认值的方法

bash 复制代码
const model = defineModel({
  default: "this is a default val"
});

此时,我们将 model 赋值给子组件里面的 input 作为响应数据,更新输入框,我们发现父组件的值会同步变化,且控制台没有报错或者警告信息...这样就没有了之前繁琐的 update 更新 emit 事件操作了

组件的多个 v-model

App.vue

html 复制代码
<script setup>
  import Child from "./components/Child.vue";
  import { ref } from "vue";
  const tips = ref(undefined);
  const title = ref("title");
</script>

<template>
  <h3>parent:tips {{ tips }}</h3>
  <h3>parent title:{{ title }}</h3>
  <Child v-model="tips" v-model:title="title" />
</template>

<style scoped></style>

Child.vue

html 复制代码
<template>
  <div>
    <h3>child props:{{ model }}</h3>
    <h3>child props:{{ title }}</h3>
    <h3>{{ title }}</h3>
    <input v-model="title" />
  </div>
</template>

<script setup>
  import { ref } from "vue";

  const msg = ref("this is a msg");
  const model = defineModel({
    default: "this is a default val",
  });

  const title = defineModel("title", { default: "title from parent..." });
</script>
<style lang="less" scoped></style>

经过实战测试,页面正常显示运行,没有显示报错日志

还有更多的特性大家可以自己看官网,对实践其他的新特性

具体参考:cn.vuejs.org/guide/compo...

相关推荐
只会cv的前端攻城狮1 分钟前
Elpis-Core — 融合 Koa 洋葱圈模型实现服务端引擎
前端·后端
Java小卷40 分钟前
流程设计器为啥选择diagram-js
前端·低代码·工作流引擎
HelloReader1 小时前
Isolation Pattern(隔离模式)在前端与 Core 之间加一道“加密网关”,拦截与校验所有 IPC
前端
兆子龙2 小时前
从 float 到 Flex/Grid:CSS 左右布局简史与「刁钻」布局怎么搞
前端·架构
YukiMori232 小时前
一个有趣的原型继承实验:为什么“男人也会生孩子”?从对象赋值到构造函数继承的完整推演
前端·javascript
_哆啦A梦2 小时前
Vibe Coding 全栈专业名词清单|设计模式·基础篇(创建型+结构型核心名词)
前端·设计模式·vibecoding
百里静修2 小时前
一个 Hook 拦截所有 AJAX 请求:ajax-hooker 使用指南与原理
前端
摸鱼的春哥2 小时前
惊!黑客靠AI把墨西哥政府打穿了,海量数据被黑
前端·javascript·后端
小兵张健2 小时前
Playwright MCP 截图标注方案调研(推荐方案1)
前端·javascript·github
小兵张健3 小时前
AI 页面与交互迁移流程参考
前端·ai编程·mcp