vue官方为什么要提供作用域插槽?有什么用处?

vue官方为什么要提供作用域插槽?有什么用处?插槽大家都了解,也都用过。目的就是为了更好的实现代码的复用,严格来说,在vue框架设计层面,他们考虑的就是,如何尽可能的减少程序员的工作量。能让代码复用的情况,绝不让大家二次编写代码。

插槽的诞生,严格来说,就是为了弥补组件(组件本身就是可以复用的代码,但是它可能在某些场景下,体型太庞大了。我们可能会仅仅想修改里面某一个小模块的数据而已。)

正是因为有这个实际需求,插槽就诞生了。名副其实的代码复用。


那么官方为什么要提供作用域插槽?目的就是为了让我们更加充分的可以修改编辑当前作用域之内的数据情况。尴尬的情况就会发生:例如

父组件,想去修改子组件插槽内的数据对象,结果会报错,说修改不了。但是如果用了作用域插槽,父组件就可以去修改子组件插槽内的数据对象了。

复制代码
<current-user>
<template v-slot:default="slotProps">
{{ slotProps.user.firstName }}
</template>
</current-user>

如图,所示,我们这个子组件内容,明确调用了一个v-slo属性标签,声明了一个具名插槽(其实就是给插槽设置一个名字而已。拿着这个名字去调用它里面的数据而已。)。

有了这个修饰后,在任意的父组件内,只要你调用了子组件,里面的插槽绑定的数据对象,都可以在父组件内随意修改。

复制代码
<span>
<slot v-bind:user="user">
{{ user.lastName }}
</slot>
</span>

如图,我们在子组件内,给插槽捆绑了一个user对象。这个捆绑的user对象,到了父组件内,也是可以被随意修改的。

相关推荐
We་ct10 分钟前
LeetCode 112. 路径总和:两种解法详解
前端·算法·leetcode·typescript
倚肆13 分钟前
WebSocket连接教程示例(Spring Boot + STOMP + SockJS + Vue)
vue.js·spring boot·websocket
Hello.Reader26 分钟前
Tauri 项目结构前端壳 + Rust 内核,怎么协作、怎么构建、怎么扩展
开发语言·前端·rust
Cache技术分享30 分钟前
331. Java Stream API - Java Stream 实战案例:找出合作最多的作者对
前端·后端
We་ct44 分钟前
LeetCode 129. 求根节点到叶节点数字之和:两种解法详解(栈+递归)
前端·算法·leetcode·typescript
Joker Zxc1 小时前
【前端基础(Javascript部分)】1、JavaScript的基础知识(组成、应用、编写方式、注释)
开发语言·前端·javascript
HelloReader1 小时前
Tauri 项目结构前端壳 + Rust 内核,怎么协作、怎么构建、怎么扩展
前端
Lee川1 小时前
深入浅出:从JavaScript内存模型理解“深拷贝”的必要性与实现
javascript
HelloReader1 小时前
Tauri 前端配置把任何前端框架“正确地”接进 Tauri(含 Vite/Next/Nuxt/Qwik/SvelteKit/Leptos/Trunk)
前端
用户5757303346241 小时前
🔥 面试官:手写 Promise 封装 AJAX?这 5 个考点 90% 的人跪了!
javascript