Vue组件上使用v-model之单选框
更新时间:2022年10月13日 16:24:24 作者:Zhouxs-_-
这篇文章主要介绍了Vue组件上使用v-model之单选框,代码分为子组件内容和父组件内容,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
先给大家介绍下Vue组件上使用v-model之单选框的实例代码。
子组件内容:
<template> <div> <input type="radio" :id="valueName" :value="valueName" :checked="picked === valueName" :picked="picked" @click="$emit('change', $event.target.value)" /> <label :for="valueName">{{ valueName }}</label> </div> </template> <script> export default { props: ["picked", "valueName"], model: { prop: "picked", event: "change", }, computed: {}, methods: {}, }; </script> <style> </style>
父组件内容:
<template> <div> <child-radio v-for="valueName in valueNames" :key="valueName" v-model="picked" :valueName="valueName" ></child-radio> 显示父组件单选的内容:{{ picked }} --> </div> </template> <script> import ChildRadio from "./ChildRadio.vue"; export default { components: { ChildRadio }, data() { return { picked: "", // valueNames: ["One", "Two", "Three"], }; }, }; </script> <style> </style>
vue组件v-model
vue中数据数据流向
vue中数据流向是单向的,也就是说我们不能直接修改props中的值所以我们都会
<template> <div> <Renderer :data='data' @updateValue='updateValue'/> </div> </template> <script setup> 我这里使用unplugin-auto-import所以不必导入ref import Renderer from "./components/Render.vue" let data = ref('0'); 这样的方式修改父组件给我们传递的值 const updateValue = (value) =>{ data.value = value; } </script>
<template> <div> <input type="text" v-model="content" @input="loadValue "> </div> </template> <script setup> const emit = defineEmits(); let content = ref(''); const loadValue = () => { emit('updateValue', content.value); } </script>
因为这中操作太频繁了所以vue新增v-model:data='data‘这种方式修改父组件数据
<template> <div> 第一个data是,如果需要修改,修改当前组件的那个值 <Renderer v-model:data="data"/> </div> </template> <script setup> import Renderer from "./components/Render.vue" let data = ref('0'); </script>
<template> <div> <input type="text" v-model="content" @input="updateValue"> </div> </template> <script setup> let content = ref(''); const emit = defineEmits(); const updateValue = ()=>{ emit('update:data', content.value); } </script>
现在v-model可以自定义修饰符
//vue2提供的修饰符 v-model.trim(去掉两端空格) v-model.number(只输入number) v-model.lazy(change事件触发)
<template> <div> <Renderer v-model:data.capitalize="data"/> {{data}} </div> </template> <script setup> import Renderer from "./components/Render.vue" let data = ref('0'); </script>
<template> <div> <input type="text" v-model="content" @input="updateValue" /> </div> </template> <script setup> const props = defineProps({ dataModifiers: Object }); let content = ref(''); const emit = defineEmits(); const updateValue = () => { if (props.dataModifiers.capitalize) { content.value = content.value.charAt(0).toUpperCase() + content.value.slice(1) } emit('update:data', content.value); } </script>
到此这篇关于Vue组件上使用v-model之单选框的文章就介绍到这了,更多相关Vue 使用v-model单选框内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
uniapp实现省市区三级级联选择功能(含地区json文件)
这篇文章主要给大家介绍了关于uniapp实现省市区三级级联选择功能(含地区json文件)的相关资料,级级联是一种常见的网页交互设计,用于省市区选择,它的目的是方便用户在一系列选项中进行选择,并且确保所选选项的正确性和完整性,需要的朋友可以参考下2024-06-06
最新评论