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

/ 6,002评论 / 26727阅读 / 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. WilliamamoRi说道:

    укладка кафельной плитки цена работы за м2 укладка кафельной плитки в спб цены

  2. Сервисный центр предлагает ремонт гироскутеров hoverbot в москве ремонт гироскутера hoverbot недорого

  3. DennisBob说道:

    GabaPharm Gabapentin: GabaPharm Gabapentin – buy gabapentin online

  4. May I simply say what a comfort to discover someone who actually knows what they are discussing online. You definitely realize how to bring a problem to light and make it important. A lot more people need to check this out and understand this side of your story. It’s surprising you are not more popular given that you certainly possess the gift.

  5. Тут можно преобрести купить сейф под карабин сейф сейфы оружейный оружие

  6. download tiktok说道:

    When I originally left a comment I appear to have clicked on the -Notify me when new comments are added- checkbox and from now on each time a comment is added I recieve four emails with the exact same comment. Perhaps there is an easy method you are able to remove me from that service? Thank you.

  7. Тут можно преобрести сейф огнестойкий купить купить огнеупорный сейф

  8. CurtisTraup说道:

    furosemide fur pharm furosemide furosemide furpharm.com

  9. Louisexhix说道:

    nhà cái ST666
    ST666 – Nhà Cái Uy Tín Hàng Đầu Việt Nam

    ST666 là một trong những nhà cái uy tín số 1 tại Việt Nam, cung cấp đa dạng các trò chơi cá cược hấp dẫn như cá cược thể thao, casino, xổ số, đá gà, bắn cá, và nhiều trò chơi thú vị khác. Không chỉ vậy, ST666 còn mang đến các chương trình khuyến mãi hấp dẫn, giúp người chơi nhận được nhiều ưu đãi hấp dẫn khi tham gia.

    Trò Chơi Cá Cược Tại ST666
    ST666 cung cấp các trò chơi cá cược đa dạng, đáp ứng nhu cầu của mọi đối tượng người chơi. Các trò chơi nổi bật tại ST666 bao gồm:

    Cá Cược Thể Thao: Các sự kiện thể thao hấp dẫn từ bóng đá, tennis đến các môn thể thao khác.
    Casino: Trải nghiệm các trò chơi casino với chất lượng cao như blackjack, baccarat, roulette, và các trò chơi slot machines.
    Đá Gà: Trận đấu đá gà gay cấn, nơi người chơi có thể tham gia cá cược và theo dõi những trận đấu kịch tính.
    Xổ Số: Chơi xổ số và thử vận may để nhận những phần thưởng giá trị.
    Bắn Cá: Trò chơi bắn cá với đồ họa sống động và hấp dẫn.
    Esports: Tham gia cá cược vào các trận đấu thể thao điện tử hấp dẫn với các đội tuyển hàng đầu.
    Khuyến Mãi Hấp Dẫn
    ST666 luôn có các chương trình khuyến mãi hấp dẫn để tri ân người chơi, bao gồm:

    Khuyến Mãi 100% Nạp Lần Đầu: Người chơi mới khi đăng ký tài khoản và nạp tiền lần đầu sẽ nhận được khuyến mãi nạp tiền lên tới 100%.
    Bảo Hiểm Casino: ST666 cung cấp bảo hiểm cho các trò chơi casino, giúp người chơi giảm thiểu rủi ro khi tham gia.
    Khuyến Mãi Thể Thao: Các chương trình khuyến mãi hấp dẫn dành riêng cho cá cược thể thao, giúp người chơi gia tăng cơ hội chiến thắng.
    Đăng Ký và Đăng Nhập ST666
    Để bắt đầu trải nghiệm các trò chơi và tham gia cá cược tại ST666, người chơi cần thực hiện các bước đơn giản sau:

    Đăng Ký: Tạo tài khoản tại ST666 để nhận các ưu đãi và khuyến mãi hấp dẫn.
    Đăng Nhập: Sau khi đăng ký thành công, người chơi có thể đăng nhập vào tài khoản để tham gia các trò chơi cá cược trực tuyến.
    Nạp Tiền và Rút Tiền: ST666 hỗ trợ nhiều phương thức nạp và rút tiền linh hoạt, giúp người chơi giao dịch nhanh chóng và an toàn.
    ST666 – Nơi Gửi Gắm Niềm Tin
    ST666 không chỉ là nhà cái mà còn là nơi cung cấp môi trường cá cược công bằng và minh bạch. Người chơi luôn cảm thấy an tâm với các chính sách bảo mật chặt chẽ và dịch vụ hỗ trợ khách hàng 24/7. ST666 xứng đáng là điểm đến tin cậy cho những ai yêu thích cá cược trực tuyến.

    Thông Tin Liên Hệ
    Nếu bạn có bất kỳ câu hỏi hay thắc mắc nào, vui lòng liên hệ với ST666 qua các kênh hỗ trợ khách hàng. Chúng tôi luôn sẵn sàng giải đáp và hỗ trợ bạn.

    CEO & Founder: Đặng Nhất Nam
    Facebook ST666: Cập nhật những tin tức mới nhất và nhận các khuyến mãi hấp dẫn tại trang Facebook chính thức của ST666.

  10. Тут можно преобрести сейф жаростойкий сейф несгораемый

  11. Truly enjoyed this entry. It provided plenty of useful insights. Great effort!

  12. CurtisTraup说道:

    cheapest Gabapentin GabaPharm Buy gabapentin for humans Buy gabapentin for humans

  13. turmeric hack说道:

    Excellent entry. I discovered the information highly helpful. Appreciated the way you clarified the content.

  14. Lloydlania说道:

    https://erepharm.com/# best ed pills online

  15. DennisBob说道:

    furpharm: buy furosemide online – cheapest lasix

  16. Robertmep说道:

    https://erepharm.com/# cheapest ed pills ere pharm

  17. DennisBob说道:

    buy rybelsus rybpharm: rybpharm – rybpharm

  18. Тут можно преобрести сейф огнеупорный купить огнеупорные сейфы

  19. Trevorapodo说道:

    Бездепозиты — отличный способ погрузиться в мир азартных игр без финансовых потерь. https://t.me/s/bonus_bezdepozita предоставляют возможность игрокам протестировать разные игровые автоматы и даже выиграть реальные деньги при соблюдении условий бонуса. Для получения бонуса необходимо пройти регистрацию на сайте казино и активировать предложение в личном кабинете. Стоит отметить, что все виды бездепозитных бонусов сопровождаются определёнными условиями использования: ограничение по времени.

  20. Тут можно преобрести противопожарный сейф сейф огнеупорный купить

  21. I’m amazed, I must say. Seldom do I come across a blog that’s equally educative and engaging, and without a doubt, you’ve hit the nail on the head. The issue is something not enough men and women are speaking intelligently about. Now i’m very happy I stumbled across this during my hunt for something concerning this.

  22. CurtisTraup说道:

    GabaPharm cheapest Gabapentin GabaPharm GabaPharm Gabapentin

  23. CurtisTraup说道:

    furpharm fur pharm lasix

  24. DennisBob说道:

    kamagra oral jelly: Kamagra Kam Pharm – buy kamagra oral jelly Kam Pharm

  25. I need to to thank you for this good read!! I absolutely loved every bit of it. I have you saved as a favorite to look at new stuff you post…

  26. Тут можно преобрести оружейные шкафы и сейфы сейф для оружия купить москва

  27. Truly enjoyed going through this entry. It’s very articulate and filled with useful details. Thank you for sharing this.

  28. Тут можно преобрести оружейный шкаф купить шкаф для оружия купить

  29. DennisBob说道:

    ED meds online with insurance: erepharm.com – ED meds online

  30. Terrific article. It’s extremely articulate and full of valuable details. Thanks for providing this content.

  31. Boostaro Reviews说道:

    This article is fantastic. I picked up a lot from going through it. The details is extremely enlightening and arranged.

  32. Тут можно преобрести сейф для сайги 12 сколько стоит сейф для ружья

  33. wool product说道:

    Hi! Do you know if they make any plugins to assist with SEO?
    I’m trying to get my website to rank for some targeted keywords but I’m not seeing very good gains.
    If you know of any please share. Appreciate it! I saw similar text here:
    Eco bij

  34. CurtisTraup说道:

    GabaPharm Gabapentin cheapest Gabapentin GabaPharm buy gabapentin online

  35. Robertmep说道:

    https://kampharm.shop/# buy kamagra oral jelly Kam Pharm

  36. profi teh remont说道:

    Сервисный центр предлагает качественый ремонт планшетов alldocube ремонт планшета alldocube на дому

  37. CurtisTraup说道:

    ED meds online with insurance best ed pills online ED pills non prescription

  38. HDCHASC说道:

    Leukemia. Lewis hamilton. President trump. Omniscient. Pumpkin. Michael j. fox. Wild boar. Lynda carter. Palisades. Armstrong. Associative property. Wichita kansas. Tim conway. Bow. Meg. New brunswick. Nolan ryan. The morning show. Steven spielberg. History of thanksgiving. Museum of modern art. Instagran. Gladiator. Dick butkus. Analysis. Xenophobic. Dak prescott rushing stats. The lego movie. Calcium. Che. Smithsonian museums. Saab. Keloid. Stagecoach. Put in bay. Spencer. Cast of 16 candles. Astigmatism. Cellulitis. Pneumothorax. Latimes. Rochester mn. Guangzhou. Bonnaroo. Prospective. Columbo. Define. Avogadros number. https://2025.uj74.ru/BFUVT.html
    Rubbing alcohol. Palmdale. Peter falk. Delusional. Pandora. Low blood pressure. Amitabh bachchan. How many people died in 911. Ithaca. Mia meaning. Salvation army. New brunswick. Philly eagles. Magnum opus. Armor. Banal. Sea moss. Yellow. Ted williams. Bridge. Libra personality. Copa america final. A quiet place ii. Committee. Eleanor roosevelt. Daphne. Methamphetamine. En. Mookie betts stats. Gaslighting. Instgram. Removed. Skull. The happening. Pandan. Control. Aids. Jaguars. Mike johnson. Heyday. Israel gaza. John cena movies and tv shows. Voyager. Clarksville tn. Culture. Stevia. Brokeback mountain. Viagra. Premonition. Munich. Napolean. Kalanchoe. Cacophony. Kaka. Leukoplakia. Mark cuban. Homage. Will arnett movies and tv shows. Laverne and shirley. 27 club.

  39. Lloydlania说道:

    https://kampharm.shop/# buy kamagra oral jelly Kam Pharm

  40. DennisBob说道:

    kamagra oral jelly: kampharm shop – kamagra oral jelly

  41. Тут можно преобрести сейф для оружия купить москва сейф купить оружейный

  42. profi teh remont说道:

    Сервисный центр предлагает ремонт кофемашины fiamma центр ремонта кофемашины fiamma

  43. Pure slim X说道:

    Truly liked going through this post. It’s very clear and full of valuable information. Many thanks for providing this.

  44. Сервисный центр предлагает ремонт компьютеров riwer на дому срочный ремонт компьютеров riwer

  45. Тут можно преобрести купить сейф для оружия сейф купить для ружья

  46. Тут можно преобрести купить огнеупорный сейф купить огнестойкий сейф

  47. CarrollWip说道:

    deneme bonusu veren siteler denemebonusu2026.com https://matadorbet.bid/# matadorbet

发表回复

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