vue3 v-model自定义修饰符写法

简介: vue3 v-model自定义修饰符写法
在vue3 v-model是破坏性的更新的
c-model在组件也很重要
v-model是一个语法糖 由emit+props组合而成
1.默认值改变
props:value==》(vue3)modelValue
事件:input==>(vue3)update:modelValue(不可改名哦);
新增多个v-model和自定义修饰符

上案例:
App.vue

<template>
  <button @click="flag=!flag;title='我是烟火'" 
       style="position:absolute;top:10%">切换  {{flag}}</button>  
     <Dialog v-model="flag"   v-model:title="title" @clicks='click'></Dialog>
 
</template> 
<script   setup lang="ts">
import  {ref} from 'vue'
import  Dialog from './components/Dialog.vue' 
const flag=ref<Boolean>(true);
const title=ref<string>('我是烟火')
    //vue2的自定义事件  子组件传输emit
  const clicks=(fla:string)=>{
    title.value=fla;
  }
</script>

<style scoped>
 
</style>

Dialog.vue

<template>
    <div class="dialog" v-if="modelValue">
       <div class="dialog-header">
           <div>标题--{{title}}</div>
           <div @click="close">x</div>
       </div>
       <div class="dialog-content">
           内容
       </div>
    </div>
</template>

<script setup lang="ts">
import { defineProps, defineEmits } from "vue"

type Props={
    modelValue:boolean  ,//接收的是默认值v-model="flag"  
    title:string,         //接收的是自定义的v-model:title="title"
}
const PropsData= defineProps<Props>()
const  emit=defineEmits(['update:modelValue','update:title','clicks'])
const close=()=>{ 
    // 传过来的是modelValue值是false所以update:modelValue直接更改父元素的flag存储的布尔值
     emit('update:modelValue',false);
    // 传过来的是title值是‘我是烟火’所以update:title直接更改父元素的title存储的string值
     emit('update:title','我是炮仗');
     //你也可以使用vue2的写法(自己想咋写都行不推荐):父组件去接收自定义事件
       emit('clicks','我是炮仗');
}
</script>

<style scoped lang="less">
.dialog{
    width: 300px;height:300px;
    border:1px solid red;
    position: absolute;
    left:50%;right: 50%;
    transform: translate(-50%,-50%);
    &-header{
        border-bottom: 1px solid red;
        display: flex;
        justify-content: space-between;
        padding: 10px;
    }
    &-content{
                padding: 10px;

    }
}
</style>

2.带自定义修饰符的写法
在这里插入图片描述

<template>
<div class="" style="position:absolute;top:10%">
  <button @click="flag=!flag;title='我是烟火'"  >{{flag}}{{title}}</button>
       
 </div>
     <!-- 绑定在v-model上或者是v-model的修饰符(v-model.xx='' 子组件接收的都是boolean值)
      v-model:title.aa="title"   :title是传输的正常值 .aa是布尔值
      -->
     <Dialog v-model="flag" v-model:title.aa="title" v-model.xiaozhu="flag"></Dialog>
</template> 
<script   setup lang="ts">
import  {ref,Directive, DirectiveBinding} from 'vue' 
import  Dialog from './components/Dialog.vue' 
const flag=ref<Boolean>(true);
const title=ref<string>('我是烟火') 
const aa=ref('') 
</script>

<style scoped>
 
</style>
<template>
    <div class="dialog" v-if="modelValue">
       <div class="dialog-header">
           <div>标题--{{title}}</div>
           <div @click="close">x</div>
       </div>
       <div class="dialog-content">
           内容
       </div>
    </div>
</template>

<script setup lang="ts">
import { defineProps, defineEmits } from "vue"

type Props={
    modelValue:boolean  ,//接收的是默认值v-model="flag"
    title:string,
//  xiaozhu其值为 true——因为 xiaozhu 被设置在了写为 v-model.xiaozhu="flag" 的 v-model 绑定上 
    modelModifiers?:{//v-model加的修饰符v-model.xiaozhu="flag" 默认的是modelModifiers
      xiaozhu:boolean 
    },
//aa其值为 true——因为 aa 被设置在了写为 v-model:title.aa="title" 的 v-model 绑定上
//v-model加的修饰符 v-model:title.aa="title"不在是默认的modelModifiers而是titleModifiers
    titleModifiers?:{        
      aa:boolean
    }
}
const PropsData= defineProps<Props>()
const  emit=defineEmits(['update:modelValue','update:title'])
const close=()=>{
    if(PropsData.titleModifiers?.aa){
      emit('update:title','我是你aa')
    }else{
      emit('update:title','我是bb')
        
    }
    // 传过来的是modelValue值是false所以update:modelValue直接更改父元素的flag存储的布尔值
    emit('update:modelValue',false);
}
</script>

<style scoped lang="less">
.dialog{
    width: 300px;height:300px;
    border:1px solid red;
    position: absolute;
    left:50%;right: 50%;
    transform: translate(-50%,-50%);
    &-header{
        border-bottom: 1px solid red;
        display: flex;
        justify-content: space-between;
        padding: 10px;
    }
    &-content{
                padding: 10px;

    }
}
</style>
相关文章
|
9天前
|
JavaScript API 数据处理
vue3使用pinia中的actions,需要调用接口的话
通过上述步骤,您可以在Vue 3中使用Pinia和actions来管理状态并调用API接口。Pinia的简洁设计使得状态管理和异步操作更加直观和易于维护。无论是安装配置、创建Store还是在组件中使用Store,都能轻松实现高效的状态管理和数据处理。
38 3
|
2月前
|
前端开发 JavaScript 测试技术
Vue3中v-model在处理自定义组件双向数据绑定时,如何避免循环引用?
Web 组件化是一种有效的开发方法,可以提高项目的质量、效率和可维护性。在实际项目中,要结合项目的具体情况,合理应用 Web 组件化的理念和技术,实现项目的成功实施和交付。通过不断地探索和实践,将 Web 组件化的优势充分发挥出来,为前端开发领域的发展做出贡献。
39 8
|
2月前
|
存储 JavaScript 数据管理
除了provide/inject,Vue3中还有哪些方式可以避免v-model的循环引用?
需要注意的是,在实际开发中,应根据具体的项目需求和组件结构来选择合适的方式来避免`v-model`的循环引用。同时,要综合考虑代码的可读性、可维护性和性能等因素,以确保系统的稳定和高效运行。
32 1
|
2月前
|
JavaScript
Vue3中使用provide/inject来避免v-model的循环引用
`provide`和`inject`是 Vue 3 中非常有用的特性,在处理一些复杂的组件间通信问题时,可以提供一种灵活的解决方案。通过合理使用它们,可以帮助我们更好地避免`v-model`的循环引用问题,提高代码的质量和可维护性。
42 1
|
3天前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
34 1
|
14天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
2月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
45 1
vue学习第一章
|
2月前
|
JavaScript 前端开发 索引
vue学习第三章
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中的v-bind指令,包括基本使用、动态绑定class及style等,希望能为你的前端学习之路提供帮助。持续关注,更多精彩内容即将呈现!🎉🎉🎉
32 1
|
2月前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
39 1
vue学习第四章
|
2月前
|
JavaScript 前端开发 算法
vue学习第7章(循环)
欢迎来到瑞雨溪的博客,一名热爱JavaScript和Vue的大一学生。本文介绍了Vue中的v-for指令,包括遍历数组和对象、使用key以及数组的响应式方法等内容,并附有综合练习实例。关注我,将持续更新更多优质文章!🎉🎉🎉
30 1
vue学习第7章(循环)

热门文章

最新文章