vue3:setup语法糖

简介:

1.setup语法糖简介

直接在script标签中添加setup属性就可以直接使用setup语法糖了。

使用setup语法糖后,不用写setup函数;组件只需要引入不需要注册;属性和方法也不需要再返回,可以直接在template模板中使用

  <template>
    <my-component @click="func" :numb="numb"></my-component>
  </template>
  <script setup>
    import {ref} from 'vue';
    import myComponent from '@/component/myComponent.vue';
    //此时注册的变量或方法可以直接在template中使用而不需要导出
    const numb = ref(0);
    let func = ()=>{
      numb.value++;
    }
  </script>


2.setup语法糖中新增的api

defineProps:子组件接收父组件中传来的props

defineEmits:子组件调用父组件中的方法

defineExpose:子组件暴露属性,可以在父组件中拿到


2.1defineProps

父组件代码

  <template>
    <my-component @click="func" :numb="numb"></my-component>
  </template>
  <script setup>
    import {ref} from 'vue';
    import myComponent from '@/components/myComponent.vue';
    const numb = ref(0);
    let func = ()=>{
      numb.value++;
    }
  </script>


子组件代码

  <template>
    <div>{{numb}}</div>
  </template>
  <script setup>
    import {defineProps} from 'vue';
    defineProps({
      numb:{
        type:Number,
        default:NaN
      }
    })
  </script>
相关文章
|
5天前
|
JavaScript 索引
Vue 2和Vue 3的区别以及实现原理
Vue 2 的响应式系统通过Object.defineProperty来实现,它为对象的每个属性添加 getter 和 setter,以便追踪依赖并响应数据变化。
20 9
|
5天前
|
JavaScript 调度
Vue3 使用 Event Bus
Vue3 使用 Event Bus
10 1
|
5天前
|
JavaScript
Vue3 : ref 与 reactive
Vue3 : ref 与 reactive
9 1
|
6天前
|
JavaScript
|
5天前
Vue3 使用mapState
Vue3 使用mapState
9 0
|
前端开发 API
Vue3入门到精通-setup
Vue3入门到精通-setup
|
1天前
|
JavaScript 前端开发
Vue项目使用px2rem
Vue项目使用px2rem
|
1天前
|
JavaScript 前端开发
vue动态添加style样式
vue动态添加style样式
|
1天前
|
JavaScript
vue中watch的用法
vue中watch的用法
|
7天前
|
JavaScript 前端开发
vue学习(6)
vue学习(6)
25 9