Skip to content

搞英语 → 看世界

翻译英文优质信息和名人推特

Menu
  • 首页
  • 作者列表
  • 独立博客
  • 专业媒体
  • 名人推特
  • 邮件列表
  • 关于本站
Menu

Vue中如何设置props的默认值?

Posted on 2022-05-16

NpN8WH8v6CfA6j7dKAzuoiE5Lit2-76b3ky9.jpe

\ 当我们在 Vue 中使用组件时,我们经常使用属性或道具将自定义的数据块向下传递给子组件。例如,我们可以告诉我们的子组件,对于这个版本的组件,“name”被设置为“my-component”:

\

 <Component name="my-component" />

\ 如果我们尝试在没有name属性的情况下调用这个组件,它会在代码中返回undefined ,或者在 HTML 中呈现时就像没有文本一样。假设我们的Component看起来像这样:

\

 <script> export default { props: { name: String }, mounted() { console.log(this.name); } } </script> <template> <p> Hi  </p> </template>

\ 我们的组件所做的只是定义了一个名为name类型的属性String ,并且控制台记录了这个属性。它还以Hi 的形式显示它。这里唯一的问题是,如果在调用组件时未定义name ,则不会给出默认名称。

\

如何使用 Options API 在 Vue 中设置默认道具值?

在 Vue 中设置默认属性值很容易。如果您使用的是 Options API,那么就像将我们的属性扩展为对象一样简单。例如,如果我们希望我们的name有一个默认值“ there ”,那么我们更新我们的 prop 看起来像这样:

\

 export default { props: { name: { type: String, default: "there" } }, mounted() { console.log(this.name); } }

\ 现在,如果没有给出名字,消息将简单地说“你好”。

\

如何在 Composition API 中设置默认道具值?

在组合 API 中,定义道具使用defineProps函数。此函数遵循与 Options API 中定义的 props 相同的语法。

\ 定义一个没有默认值的道具看起来像这样:

\

 import { defineProps } from 'vue'; const props = defineProps({ name: String });

\ 然后添加一个默认值,我们将name扩展为具有默认属性,就像以前一样:

\

 import { defineProps } from 'vue'; const props = defineProps({ name: { type: String, default: "there" } });

\

Vue中如何根据需要设置prop?

为了避免在属性上设置默认值,我们可以通过使用required字段来强制要求属性。

\ 例如,如果我们想要定义我们的name属性,我们只需将required设置为true :

\

 <script setup> import { defineProps } from 'vue'; const props = defineProps({ name: { type: String, required: true } }); </script>

也在这里发布

原文: https://hackernoon.com/how-to-set-default-value-of-props-in-vue?source=rss

本站文章系自动翻译,站长会周期检查,如果有不当内容,请点此留言,非常感谢。
  • Abhinav
  • Abigail Pain
  • Adam Fortuna
  • Alberto Gallego
  • Alex Wlchan
  • Answer.AI
  • Arne Bahlo
  • Ben Carlson
  • Ben Kuhn
  • Bert Hubert
  • Bits about Money
  • Brian Krebs
  • ByteByteGo
  • Chip Huyen
  • Chips and Cheese
  • Christopher Butler
  • Colin Percival
  • Cool Infographics
  • Dan Sinker
  • David Walsh
  • Dmitry Dolzhenko
  • Dustin Curtis
  • Elad Gil
  • Ellie Huxtable
  • Ethan Marcotte
  • Exponential View
  • FAIL Blog
  • Founder Weekly
  • Geoffrey Huntley
  • Geoffrey Litt
  • Greg Mankiw
  • Henrique Dias
  • Hypercritical
  • IEEE Spectrum
  • Investment Talk
  • Jaz
  • Jeff Geerling
  • Jonas Hietala
  • Josh Comeau
  • Lenny Rachitsky
  • Liz Danzico
  • Lou Plummer
  • Luke Wroblewski
  • Matt Baer
  • Matt Stoller
  • Matthias Endler
  • Mert Bulan
  • Mostly metrics
  • News Letter
  • NextDraft
  • Non_Interactive
  • Not Boring
  • One Useful Thing
  • Phil Eaton
  • Product Market Fit
  • Readwise
  • ReedyBear
  • Robert Heaton
  • Rohit Patel
  • Ruben Schade
  • Sage Economics
  • Sam Altman
  • Sam Rose
  • selfh.st
  • Shtetl-Optimized
  • Simon schreibt
  • Slashdot
  • Small Good Things
  • Taylor Troesh
  • Telegram Blog
  • The Macro Compass
  • The Pomp Letter
  • thesephist
  • Thinking Deep & Wide
  • Tim Kellogg
  • Understanding AI
  • 英文媒体
  • 英文推特
  • 英文独立博客
©2025 搞英语 → 看世界 | Design: Newspaperly WordPress Theme