Vue3 setup 的作用实例详解

 更新时间:2022年12月29日 16:04:07   作者:清风 与我  
setup 用来写组合式 API,从生命周期的角度,相当于取代了 beforeCreate(),这篇文章主要介绍了Vue3 setup 的作用,需要的朋友可以参考下

从 vue2 升级 vue3,vue3 是可以兼容 vue2。所以 vue3 可以采用 vue2 的选项式 API,但是 vue2 不能使用 vue3 的组合式 API。

由于选项式 API 一个变量存在于多处,如果出现问题,就需要去涵盖多个函数。项目越大,排查的难度也就越大。

setup 具体怎么用:

setup 用来写组合式 API,从生命周期的角度,相当于取代了 beforeCreate()

setup 的数据和方法如何使用?

1.setup(){} 内部的属性和方法,必须用 return 暴露出来。

将属性挂载到实例上,否则没有办法使用。
语法糖:写在 script 开始标签中,内部的属性和方法,无需 return 暴露;
无法和选项式 API 混用。

2.setup 内部使用时,没有 this

3.钩子函数可以和 setup 并列存在

4.setup 不能调用生命周期相关函数,或者嵌套存在。

5.生命周期相关函数可以调用 setup 相关的属性和方法

6.可以使用 this

setup 参数

使用 setup 时,它将接收两个参数:props 和 context

props:

  • 表示父组件给子组件传的数据;
  • props是响应式的,当数据发生改变时,自动更新
  • 因为 props 是响应式的,不能使用 Es6 的解构,如果使用会消除响应式特性(使用 toRefs)

context:

上下文环境。其中包括了,属性,插槽,自定义事件三个部分。

  • attrs:是一个非响应式对象,主要接受 no-props(非props)属性。经常用来传递一些样式/标签特有属性。
  • slots:是一个 Proxy 对象,其中 slots.default() 获取到一个数组。数组长度表示插槽的数量,数组中的元素是插槽的内容。
  • emit:因为在 setup 中没有 this,所以使用 emit 来替换之前的 this.$emit(‘自定义事件名称’,传递的值)。用于子传父时,自定义事件的触发
  • 示例:emit(‘自定义事件名称’,传递的值)

setup 特性总结:

  • 这个函数会在 created 之前执行。
  • setup 内部没有 this,不能挂载 this 相关的东西
  • setup 内部的属性和方法,必须 return 暴露出来。(语法糖中不需要)
  • setup 内部的属性都不是响应式的;
  • setup 不能调用生命周期相关函数,但生命周期相关函数可以调用 setup

setup 在代码中的使用

<script>
import { onMounted, toRefs } from "vue";
export default {
  props: {
    msg: "abc",
  },
  setup(props, context) {
    let { msg } = toRefs(props);
    let { attrs, slots, emit } = context;
    console.log(props, context);
    let num = 10;
    return {
      num,
    };
    // 和setup,嵌套的生命周期
    // onMounted(() => {
    //   console.log("onMounted", num);
    // });
  },
  // 和setup,并列的生命周期
  mounted() {
    console.log("挂载后");
    console.log(this.$options);
  },
  data() {
    return {};
  },
  methods: {},
};
</script>

总结:

以上就是 vue3 中 setup 的作用。

知识点扩展:

Vue3中setup函数的作用与实现

  • setup函数是vue3新增组件选项,其作用为

  • 配合组合式api,建立组合逻辑、创建响应式数据、创建通用函数,注册生命周期钩子的能力
  • setup函数只会在被挂载时执行
  • setup返回值有两种
  • 函数
  • 对象
  • 若为对象,则将对象包含的数据暴漏给模板使用
  • 在渲染组件的函数中从组件上取出setup,获取其执行的返回值,判断其是否为函数,并将其挂载到组件实例上
  • 若为函数,则赋值给instance.render
  • 若为对象,则将其变成响应式,并赋值给instance.setupState
export function setupComponent(instance){
    let { type,props,children}  = instance.vnode
    let {data,render,setup} = type
    //初始化属性
    initProps(instance,props);
    instance.proxy = new Proxy(instance,instanceProxy);
    if(data){
        if(!isFunction(data)){
            return console.warn('The data option must be a function.')
        }
        //给实例赋予data属性
        instance.data = reactive(data.call({}))
    }
    if(setup){
      //setup的第二个参数,包含emit,attrs,slots等
      const context = {}
      const setupResult = setup(instance.props,context)
      if(isFunction(setupResult)){
        instance.render = setupResult
      }else if(isObject(setupResult)){
        instance.setupState = proxyRefs(setupResult)
      }
    }
    if(!instance.render){
      if(render){
      instance.render = render

      }else {
        //模板编译
      }
    } 
}

同时,instance的数据代理上做出对setupState的监听

const instanceProxy = {
    get(target,key){
        const { data,props,setupState} = target
        if(data && hasOwn(data,key)){
            return data[key]
        }else if(setupState && hasOwn(setupState,key)){
          return setupState[key]
        }
        else if(props && hasOwn(props,key)){
            return props[key]
        }
        let getter = publicProperties[key]
        if(getter){
            return getter(target)
        }
    },
    set(target,key,value,receiver){
        // debugger
        const {data,props,setupState} = target
        if(data && hasOwn(data,key)){
            data[key] = value
        }else if( setupState && hasOwn(setupState,key)){
            setupState[key]  = value
        }
        else if(props && hasOwn(props,key)){
            console.warn('props not update');
            return false
        }
        return true
    }
}

到此这篇关于Vue3 setup 的作用的文章就介绍到这了,更多相关Vue3 setup 的作用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue页面批量引入组件的操作代码

    vue页面批量引入组件的操作代码

    这篇文章主要介绍了vue页面批量引入组件,本文结合示例代码给大家讲解的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-12-12
  • vue嵌入第三方页面几种常见方法

    vue嵌入第三方页面几种常见方法

    在Vue中嵌入第三方页面可以采用多种方法,例如使用<iframe>、Vue插件、动态加载第三方脚本或WebComponents,不同方法适用于不同类型的内容和项目需求,如<iframe>适用于整个网页,而动态脚本和WebComponents适合特定功能,选择合适的方法可以有效整合外部资源
    2024-09-09
  • VUE2.0中Jsonp的使用方法

    VUE2.0中Jsonp的使用方法

    使用JSONP主要是目的通过动态创建Script,动态拼接url,进而抓取数据,实现跨域。这篇文章主要介绍了VUE2.0中Jsonp的使用方法(前端),需要的朋友可以参考下
    2018-05-05
  • 一文带你掌握Vue中的路由守卫

    一文带你掌握Vue中的路由守卫

    路由守卫(Route Guards)是 Vue Router 的一个功能,它允许我们在路由发生之前执行逻辑判断,这篇文章主要为大家介绍了Vue中路由守卫的具体应用,需要的可以了解下
    2024-03-03
  • vue3+ts代理的使用

    vue3+ts代理的使用

    本文主要介绍了vue3+ts代理的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-12-12
  • vue项目启动时无法识别es6的扩展语法的解决

    vue项目启动时无法识别es6的扩展语法的解决

    启动项目时遇到ES6的拓展运算符报错可以通过切换到淘宝镜像,以及在项目根目录下新增.babelrc和postcss.config.js文件来解决,这些操作有助于正确配置项目环境,从而避免报错,并保证项目的顺利运行,希望这些经验能够帮助到遇到相同问题的开发者
    2024-10-10
  • 浅析vue-router中params和query的区别

    浅析vue-router中params和query的区别

    这篇文章主要介绍了vue-router中params和query的区别,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-12-12
  • 基于axios请求封装的vue应用实例代码

    基于axios请求封装的vue应用实例代码

    这篇文章主要给大家介绍了基于axios请求封装的vue应用的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-05-05
  • Vue $emit $refs子父组件间方法的调用实例

    Vue $emit $refs子父组件间方法的调用实例

    今天小编就为大家分享一篇Vue $emit $refs子父组件间方法的调用实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • vue3+echarts+折线投影(阴影)效果的实现

    vue3+echarts+折线投影(阴影)效果的实现

    这篇文章主要介绍了vue3+echarts+折线投影(阴影)效果的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10

最新评论