like Title,
about link:
New script setup (without ref sugar)
<template>
  <TopNavbar title="room" />
  <div>
    {{ no }}
  </div>
</template>
<script setup>
import TopNavbar from '@/layout/TopNavbar.vue'
import { defineProps, reactive } from 'vue'
defineProps({
  no: String
})
const state = reactive({
  room: {}
})
const init = async () => {
  // I want use props in this
  // const { data } = await getRoomByNo(props.no)
  // console.log(data);
}
init()
</script>
<style>
</style>
You define a prop named disabled in MyComponent. vue . ... and then add the component like this, passing in disabled . Note that :disabled="true" and just disabled mean the same thing in both cases - when props are defined or not.
What are props? In Vue, props (or properties), are the way that we pass data from a parent component down to it's child components. When we build our applications out of components, we end up building a data structure called a tree.
To use props with <script setup> you need to call defineProps() with the component prop options as the argument, this defines the props on the component instance and returns a reactive object with the props which you can use as follows:
<template>
  <TopNavbar title="room" />
  <div>
    {{ no }}
  </div>
</template>
<script setup>
import TopNavbar from "@/layout/TopNavbar.vue";
import { defineProps, reactive } from "vue";
const props = defineProps({
  no: String,
});
const { no } = toRefs(props);
const state = reactive({
  room: {},
});
const init = async () => {
  const { data } = await getRoomByNo(no.value);
  console.log(data);
};
init();
</script>
If you are using typescript the alternative way to do this is pass a type only declaration and infer the prop types from that. Pro's are that you'll get stricter type safety but you cannot have default values.
<template>
  <TopNavbar title="room" />
  <div>
    {{ no }}
  </div>
</template>
<script setup>
import TopNavbar from "@/layout/TopNavbar.vue";
import { defineProps, reactive } from "vue";
const props = defineProps<{
  no: string,
}>();
const { no } = toRefs(props);
const state = reactive({
  room: {},
});
const init = async () => {
  const { data } = await getRoomByNo(no.value);
  console.log(data);
};
init();
</script>
Defaults with type only props are now possible:
interface Props {
  msg?: string
}
const props = withDefaults(defineProps<Props>(), {
  msg: 'hello'
})
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With