首页前端开发其他前端知识vue3中setup函数的参数有什么,使用要注意哪些

vue3中setup函数的参数有什么,使用要注意哪些

时间2024-03-26 14:32:03发布访客分类其他前端知识浏览669
导读:在实际案例的操作过程中,我们可能会遇到“vue3中setup函数的参数有什么,使用要注意哪些”这样的问题,那么我们该如何处理和解决这样的情况呢?这篇小编就给大家总结了一些方法,具有一定的借鉴价值,希望对大家有所帮助,接下来就让小编带领大家一...
在实际案例的操作过程中,我们可能会遇到“vue3中setup函数的参数有什么,使用要注意哪些”这样的问题,那么我们该如何处理和解决这样的情况呢?这篇小编就给大家总结了一些方法,具有一定的借鉴价值,希望对大家有所帮助,接下来就让小编带领大家一起了解看看吧。

1.setUp函数的第1个参数props

setup(props,context){ }

第一个参数props:

props是一个对象,包含父组件传递给子组件的所有数据。

在子组件中使用props进行接收。

包含配置声明并传入的所有的属性的对象

也就是说:如果你想通过props的方式输出父组件传递给子组件的值。

你需要使用props进行接收配置。即props:{ ......}

如果你未通过Props进行接受配置,则输出的值是undefined【相关推荐:vue.js视频教程】

template>
    
  div>
    
    父组件 
  /div>
    
  no-cont :mytitle="msg" 
      othertitle="别人的标题"
      @sonclick="sonclick">
    
  /no-cont>
    
/template>
    

script>

import NoCont from "../components/NoCont.vue"
export default {

  setup () {

    let msg={

      title:'父组件给子给子组件的数据'
    }

    function sonclick(msss:string){

      console.log(msss)
    }

    return {
msg,sonclick}

  }
,
  components:{

    NoCont
  }

}
    
/script>
    
template>
    
    div @click="sonHander">
    
        我是子组件中的数据
    /div>
    
/template>
    

script>

import {
 defineComponent,setup }
     from 'vue';

export default defineComponent({

  name: 'NoCont',
 //  未进行接受
 //   props:{

 //     mytitle:{

 //         type:Object
 //     }

 //   }
,
  setup(props,context){
    
    console.log('props==>
    ',props.mytitle);
//输出的值是 undefined
    function sonHander(){

        context.emit('sonclick','子组件传递给父组件')
    }

    return {
sonHander}

  }

}
    );
    
/script>

为什么通过props.mytitle输出的值是undefined呢?

因为我们没有使用props进行接收配置。即

props:{

    mytitle:{

        type:Object
    }

}
    ,

如果我们添加上接受配置

2.参数context的讲解

第2个参数:context,是一个对象。

里面有attrs(获取当前标签上的所有属性的对象)

但是该属性是props中没有声明接收的所有的对象。

如果你使用props去获取值,同时props中你声明了你要获取的值

则:获取的值是undefined

注意点:

attrs获取值是不需要props中没有声明接收。

第1个参数props获取值是需要props中声明接收的

有emit事件分发,(传递给父组件需要使用该事件)

有slots插槽

template>
    
    div @click="sonHander">
    
        我是子组件中的数据
    /div>
    
/template>
    

script>

import {
 defineComponent,setup }
     from 'vue';

export default defineComponent({

  name: 'NoCont',
  props:{

      mytitle:{

          type:Object
      }

  }
,
  setup(props,context){

    //输出{
title:父组件传递的值}
    
    console.log('props==>
    ',props.mytitle);
    
    
    // 输出别人的标题【使用context获取值,不需要使用props去接受】
    console.log('context==>
     ',context.attrs.othertitle);
    
    
    // 输出undefined,因为context不需要使用props去接受。
    console.log('contextmytitle==>
     ',context.attrs.mytitle);

    function sonHander(){

        context.emit('sonclick','子组件传递给父组件')
    }

    return {
sonHander}

  }

}
    );
    
/script>
    

3. 子组件向父组件派发事件

template>
    
    div @click="sonHander">
    
        我是子组件中的数据
    /div>
    
/template>
    

script>

import {
 defineComponent,setup }
     from 'vue';

export default defineComponent({

  name: 'NoCont',
  props:{

      mytitle:{

          type:Object
      }

  }
,
  setup(props,context){

    function sonHander(){

        context.emit('sonclick','子组件传递给父组件')
    }

    return {
sonHander}

  }

}
    );
    
/script>
    

4.优化事件派发

我们知道第2个参数context是一个对象

并且对象中有三个属性attrs,slots,emit

在事件派发的时候,直接使用emit就ok了

template>
    
    div @click="sonHander">
    
        我是子组件中的数据
    /div>
    
/template>
    

script>

import {
 defineComponent,setup }
     from 'vue';

export default defineComponent({

  name: 'NoCont',
  props:{

      mytitle:{

          type:Object
      }

  }
,
  setup(props,{
attrs,slots,emit}
){

    //直接使用emit进行事件派发
    function sonHander(){

        emit('sonclick','子组件传递给父组件')
    }

    return {
sonHander}

  }

}
    );
    
/script>
    

5.获取父组件传递的值

我们将使用props参数获取值

以及使用attrs获取值

template>
    
hr/>
    
   h2>
    子组件/h2>
    
    div @click="sonHander">
    
        我是子组件中的数据
    /div>
    
    h2>
    使用了props声明接收==>
{
{
 mytitle  }
}
    /h2>
     
    h2>
    使用参数attrs获取==>
{
{
 attrs.othertitle  }
}
    /h2>
     
/template>
    

script>

import {
 defineComponent,setup }
     from 'vue';

export default defineComponent({

  name: 'NoCont',
  props:{

      mytitle:{

          type:Object
      }

  }
,
  setup(props,{
attrs,slots,emit}
){

    function sonHander(){

        emit('sonclick','子组件传递给父组件')
    }

    return {
sonHander,attrs}

  }

}
    );
    
/script>
    

附使用setup函数时需要注意几点:

  • setup函数的执行时机是在beforeCreate和created之间
  • 由于setup执行时机是在created之间,所以组件才刚刚被创建,而data和methods还没初始化好,所以无法在setup中使用data和methods
  • setup中this指向undefined
  • setup只能是同步的,不能是异步的

以上就是关于vue3中setup函数的参数有什么,使用要注意哪些的介绍,本文内容仅供参考,有需要的朋友可以借鉴了解看看,希望对大家学习或工作,想要了解更多欢迎关注网络,小编每天都会为大家更新不同的知识。

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

Vue

若转载请注明出处: vue3中setup函数的参数有什么,使用要注意哪些
本文地址: https://pptw.com/jishu/653561.html
在Go并发编程中sync.Once操作应用场景有什么 go语言编程实现深度优先搜索和图的广度的方法是什么

游客 回复需填写必要信息