[vue3]组件间v-bind,v-model传参(defineProps,defineEmits)

/ 6,005评论 / 26755阅读 / 2点赞

1. 自定义组件间也可以和普通标签(<div> <span>)一样指定属性传参

2. 形如(<child value="hello coolight"></child>)给组件<child>指定value属性为"hello coolight"

3. 我们也可以自己模拟v-model的效果

下面我们来聊聊怎么传参、接收与更新

传参,v-bind

<script setup>
import { toRefs } from 'vue';
const props = defineProps({
    text:{
        type:String,
        default:"默认:hello coolight",
        required:false
    }
})

const {
    text,
} = toRefs(props);
</script>

<template>
    <span>{{props.text}} - {{text}}</span>
</template>
<script setup>
import helloVue from '../../components/global/hello.vue';
</script>

<template>
    <div>
        <hello-vue />
        <hello-vue text="洛天依"/>
        <hello-vue :text="'v-bind:洛天依'" />
    </div>
</template>

v-model

一般的传参进来,组件对它是只读的,不能修改。

只读也并不完全,对于数组和对象是可以操作其内部值的。

但我们可以使用v-model指定参数,使之允许组件来修改它。

”只读“的探讨

<script setup>
import { reactive } from 'vue';
import { toRefs } from 'vue';
const props = defineProps({
    obj:{
        type:Object
    }
})

const {
    obj,
} = toRefs(props);

const btn1_click = () => {
    props.obj.hello = "coolight - 1";
}
const btn2_click = () => {
    props.obj = reactive({
        hello:"coolight - 2"
    })
}
</script>

<template>
    <div>
        <button @click="btn1_click">1: {{obj.hello}}</button>
        <button @click="btn2_click">2: {{obj.hello}}</button>
    </div>
</template>
<script setup>
import { reactive } from 'vue';
import helloVue from '../../../components/global/hello.vue';

let obj = reactive({
    hello:"洛天依"
})
</script>

<template>
    <div>
        <span>span: {{obj.hello}}</span>
        <hello-vue :obj="obj" />
    </div>
</template>

使用v-model

<script setup>
import { toRefs } from 'vue';
const props = defineProps({
    obj:{
        type:Object
    }
})
const emits =  defineEmits ({
    'update:obj':null  //null位置可以是一个检查函数,用以检查绑定这个信号的处理函数是否有接收参数等,这里就不需要了
});

const {
    obj,
} = toRefs(props);

const btn1_click = () => {
    props.obj.hello = "btn1";
}
const btn2_click = () => {
    emits('update:obj', {
        hello:"btn2"
    });
}
</script>

<template>
    <div>
        <button @click="btn1_click">{{obj.hello}} - 修改为 btn1</button>
        <button @click="btn2_click">{{obj.hello}} - 修改为 btn2</button>
    </div>
</template>
<script setup>
import { reactive } from 'vue';
import helloVue from '../../../components/global/hello.vue';

let mValue = reactive({
    obj:{
        hello:"洛天依"
    },
})
</script>

<template>
    <div>
        <span>span: {{mValue.obj.hello}}</span>
        <hello-vue v-model:obj="mValue.obj"/>
    </div>
</template>

尝试取代v-model

<script setup>
import { reactive } from 'vue';
import helloVue from '../../../components/global/hello.vue';

let mValue = reactive({
    obj:{
        hello:"洛天依"
    },
})
const change = (in_obj) => {
    console.log("我们的change");
    mValue.obj = in_obj;
}
</script>

<template>
    <div>
        <span>span: {{mValue.obj.hello}}</span>
        <!-- 也可以这样:
            <hello-vue v-model:obj="mValue.obj" @update:obj="change"/>
        -->
        <hello-vue :obj="mValue.obj" @update:obj="change"/>
    </div>
</template>
  1. I would like to thank you for the efforts you’ve put in writing this blog. I really hope to view the same high-grade blog posts by you in the future as well. In truth, your creative writing abilities has motivated me to get my own blog now 😉

  2. AlbertVed说道:

    buy clopidogrel bisulfate: buy plavix online – clopidogrel bisulfate 75 mg

  3. Brandenven说道:

    where to buy generic clomid online: buy clomid – cheap clomid pill

  4. I’m more than happy to find this great site. I wanted to thank you for your time due to this fantastic read!! I definitely loved every little bit of it and I have you saved as a favorite to check out new stuff in your site.

  5. 貼海報说道:

    I really love your site.. Very nice colors & theme. Did you develop this web site yourself? Please reply back as I’m trying to create my own personal blog and would like to know where you got this from or exactly what the theme is named. Kudos.

  6. Brandenven说道:

    amoxicillin no prescription: buy amoxil online – amoxicillin 800 mg price

  7. BernardGab说道:

    cheapest Lisinopril buy Lisinopril 1st buy Lisinopril 1st

  8. DarrenDug说道:

    https://lisinopril1st.com/# cheapest Lisinopril

  9. BernardGab说道:

    buy prinivil online buy Lisinopril 1st Lisinopril 1st

  10. Néon LED说道:

    Hi there! I just would like to give you a huge thumbs up for the great info you’ve got here on this post. I will be returning to your blog for more soon.

  11. xxnx bf说道:

    Thanks for thr great article!

  12. Узнай все о выпрямление носовой перегородкисептопластика стоимость

  13. AlbertVed说道:

    п»їplavix generic: cheapest plavix – plavix medication

  14. AlbertVed说道:

    antiplatelet drug: Clopidogrel Best Prices – Plavix generic price

  15. Узнай все о септопластика цена москвасептопластика

  16. bet tz说道:

    This is the right website for anybody who wants to understand this topic. You understand so much its almost hard to argue with you (not that I personally will need to…HaHa). You certainly put a fresh spin on a subject that has been written about for many years. Excellent stuff, just wonderful.

  17. Brandenven说道:

    priligy: priligy maxpharm – buy priligy max pharm

  18. gamdom说道:

    This is a topic which is close to my heart… Best wishes! Exactly where are your contact details though?

  19. xnxx.com说道:

    After going over a few of the blog posts on your web page, I truly like your technique of blogging. I added it to my bookmark website list and will be checking back soon. Please check out my website as well and tell me your opinion.

  20. Узнай все о операция по удалению полипа эндометрияудаление полипа шейки матки москва

  21. DarrenDug说道:

    https://cytpremium.com/# п»їcytotec pills online

  22. CurtisWer说道:

    BBgate MarketPlace 2024 Breaking Bad Gate Forum
    BBgate MarketPlace

  23. Davidhax说道:

    mexico pharmacies prescription drugs http://mexicanpharmgate.com/ mexican drugstore online

  24. Davidhax说道:

    п»їbest mexican online pharmacies http://mexicanpharmgate.com/ medicine in mexico pharmacies

  25. Alpha Bites说道:

    Adored the information offered in this entry. It’s very clear and full of useful details. Excellent effort!

  26. BernardGab说道:

    Lisinopril 1st Lisinopril 1st lisinopril1st

  27. Brandenven说道:

    amoxicillin discount: buy amoxil online – order amoxicillin online uk

  28. jumping castle说道:

    Nice post. I learn something totally new and challenging on websites I stumbleupon on a daily basis. It will always be helpful to read articles from other authors and practice a little something from their sites.

  29. AlbertVed说道:

    cytotec online: buy cytotec online – п»їcytotec pills online

  30. BernardGab说道:

    cheap plavix antiplatelet drug PlavixClo Plavix 75 mg price

  31. Brandenven说道:

    buying prednisone mexico: cheap prednisone – prednisone without prescription

  32. Davidhax说道:

    reputable mexican pharmacies online http://mexicanpharmgate.com/ mexican border pharmacies shipping to usa

  33. Great article. I discovered the information extremely helpful. Appreciated the manner you explained all the points.

  34. Georgeneume说道:

    Game keys
    Explore a World of Gaming Possibilities with ItemsforGames

    At Items4Play, we provide a active marketplace for players to purchase or exchange gaming accounts, items, and options for widely played video games. If you’re seeking to upgrade your game inventory or wanting to profit from your game account, our service provides a smooth, protected, and profitable experience.

    Why Select Items4Play?
    **Extensive Title Library**: Explore a vast selection of titles, from thrilling adventures such as Battleground and Call of Duty to captivating role-playing games like ARK: Survival Evolved and Genshin. We have everything, ensuring no gamer is excluded.

    **Range of Services**: Our products cover account purchases, in-game currency, rare collectibles, milestones, and coaching options. Whether you need help gaining levels or getting exclusive bonuses, we’ve got you covered.

    **Easy Navigation**: Navigate easily through our structured marketplace, organized in order to locate just the item you are looking for fast.

    **Safe Deals**: We prioritize your security. All exchanges on our site are conducted with the utmost security to guard your private and financial information.

    **Highlights from Our Offerings**
    – **Survival and Survival**: Games ARK: Survival Evolved and Day-Z let you explore tough settings with top-notch goods and accesses available.
    – **Tactical and Exploration**: Elevate your experience in titles like Clash Royale and Wonders Age with virtual money and options.
    – **eSports Competitions**: For competitive players, enhance your abilities with mentoring and level-ups for Val, Dota, and Legends.

    **A Platform Built for Players**
    Backed by ApexTech Innovations, a trusted business registered in Kazakhstan, ItemsforGames is a hub where video game aspirations become real. From acquiring pre-order keys for the latest titles to getting hard-to-find in-game treasures, our site fulfills every gaming requirement with skill and reliability.

    Join the gaming family today and boost your gaming experience!

    For inquiries or guidance, email us at **support@items4games.com**. Let’s game better, as one!

  35. Узнай все о удаление полипа в матке гистероскопия ценагистероскопия полипа матки цена москва

  36. Узнай все о операция по удалению полипа шейки маткиудаление полипа матки

  37. StevenWearo说道:

    amoxicillin 500mg capsules: Amoxicillin buy online – can i buy amoxicillin online

  38. porn说道:

    I needed to thank you for this fantastic read!! I certainly enjoyed every little bit of it. I have got you book marked to look at new stuff you post…

  39. StevenWearo说道:

    prednisone 2 5 mg: buy prednisone – can i buy prednisone online without a prescription

  40. Brandenven说道:

    priligy: buy priligy – cheap priligy

  41. Derekjup说道:

    how much is prednisone 5mg: raypharm – prednisone pill 10 mg

  42. Iyannanet说道:

    jack poker отзывы игроков
    jack poker отзывы онлайн

  43. Brandenven说道:

    prednisone 2 5 mg: ray pharm – order prednisone

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注