ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

vue3 modifier

2021-08-18 23:31:25  阅读:227  来源: 互联网

标签:vue const props userinput vue3 修饰符 import modifier


vue3 modifier 是什么?

modifier 中卫意思为修饰符.

在vue3中主要是用在v-model上,vue3允许我们添加自定义修饰符。

比如说这样:

<template>
    <img alt="Vue logo" src="./assets/logo.png" />
    <!-- <HelloWorld msg="Welcome to Your Vue.js App" /> -->
    <Test v-model:userinput.trimall="userinput"></Test>
    <p>{{userinput}}</p>
</template>

<script setup>
import HelloWorld from "./components/HelloWorld.vue";
import Test from "./components/Test.vue";
import {ref} from 'vue'
const userinput = ref('');

</script>

我们自定义的修饰符在子组件中如何获取呢?其实很简单,

我们v-model:msg.trimall 传递到子组件中一共有两个属性,如下所示:

const props = defineProps({
    userinput: {
        type: String,
        default: "",
    },
    userinputModifiers: {
        type: Object,
        default: () => ({}),
    },
});

我们的子组件的自定义修饰符全部存放在userinputModifiers这个对象里面,这个对象key组成是 属性+Modifiers,所以

<Test v-model:something.tom="value"></Test>

我们的子组件就会收到除去something属性之外额外的属性 somethingModifiers。

接着上面的说下去,

userinputModifiers 会有一个属性是你的修饰符名称,比如:


所以我们就可以根据这个值做我们想做的事情了.

代码示例如下:
App.vue
<template>
    <img alt="Vue logo" src="./assets/logo.png" />
    <!-- <HelloWorld msg="Welcome to Your Vue.js App" /> -->
    <Test v-model:userinput.trimall="userinput" ></Test>
    <p>{{userinput}}</p>
</template>

<script setup>
import HelloWorld from "./components/HelloWorld.vue";
import Test from "./components/Test.vue";
import {ref} from 'vue'
const userinput = ref('');

</script>

<style>
#app {
    font-family: Avenir, Helvetica, Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-align: center;
    color: #2c3e50;
    margin-top: 60px;
}
</style>

Test.vue

<template>
    <div>
        <input :value="userinput" @input="onInput" type="text" />
    </div>
</template>

<script setup>
import { getCurrentInstance, defineProps, toRef, useAttrs } from "vue";

const props = defineProps({
    userinput: {
        type: String,
        default: "",
    },
    userinputModifiers: {
        type: Object,
        default: () => ({}),
    },
});

const userinput = toRef(props, "userinput");
const instance = getCurrentInstance();

console.log("value:", props);
function onInput({ target }) {
    var value = props.userinputModifiers.trimall
        ? target.value.replace(/\s/g, "")
        : target.value;
    instance.emit("update:userinput", value);
}
</script>

注:

在vue3.2之前 还是有 useContext 这个函数的,之后这个函数被废弃了,取而代之的是 useAttrs(主要用来获取一些非props属性) 和 useSlots (如果你不编写JSX或者TSX,这个函数你应该用不到)

是故学然后在不足 23:29:33

 

标签:vue,const,props,userinput,vue3,修饰符,import,modifier
来源: https://www.cnblogs.com/alone4436/p/15159419.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有