what
编程语言里面,除了使用 if 语句来做条件判断,还有另外一个常用的就是 switch 了。
而在 vue 中,官方已经帮助我们实现了 v-if 这个指令,但是还没有 switch ,那我们能不能自己实现一个呢?
这篇文章就是来探索这个问题,并且最终实现一个 Switch 组件
以终为始
先来看看我们希望用户是如何使用 Switch 的
用 js 的方式来对比一下:
用户可以通过一个 VSwitch 组件来应用 switch 功能
通过 case 来确定匹配的条件
然后每一个 case 匹配的条件用 template 来表示
这样我们已经规定好用户该如何使用了,剩下的其实就是实现了
这一步背后的思想就是确定组件的规格,也可以说是确定组件的使用接口
how
那么我们应该如何实现呢?
我们先来思考一下 switch 的功能
拆分 Switch 功能
某个等于 case 值的那个模板显示,别的都不应该显示
举个栗子:
case = "xiaohong" 时
那么就只能显示名字为 "xiaohong" 的插槽
如果没有匹配到任何一个 case ,并且还有 defalut 插槽时,显示 defalut 插槽
当然,switch 还有更复杂的功能,我们这里先从最核心的功能入手,慢慢在复杂化(迭代思想)
实现原理
首先我们必须先知道该组件的 slots,都有哪些
在 vue3 中,我们只需要通过以下方式就可以轻松获取 slots
setup(props,{slots}){ console.log(slots) }
如果打印 slots 的话,你会发现可以得到一个对象,而 key 的值就是 slot 的名称,而 value 是一个函数,调用这个函数就可以获取到对应的 vnode。
那比如我想显示 xiaohei 这个插槽要怎么做呢?
只需要这样
setup(props, { slots }) { return () => { return slots.xiaohei() }; },
setup 除了可以返回一个对象,作为导出给 template 用的数据,还可以直接返回一个函数作为 render。
而 render 函数只要返回对应的 vnode ,那么最终就会被渲染到 view 上。
所以按照上面代码的写法的话最终会显示 xiaohei slot 内部的内容
那当明白上述知识点后,我们在回来看看第一个功能
是不是只要我们把和 case 匹配的 slots 渲染出来即可
看代码:
export default { props: ["case"], setup(props, { slots }) { console.log(slots); return () => { if (slots[props.case]) { return slots[props.case](); } }; }, };
注意哦,一定要加条件判断,因为很有可能是没有对应的 slot 的
看,懂了原理之后是不是很轻松的实现第一个功能了。
我们在来看第二个功能的时候是不是也很简单了
只需要在加一段代码即可:
export default { props: ["case"], setup(props, { slots }) { console.log(slots); return () => { if (slots[props.case]) { return slots[props.case](); } if (slots["default"]) { return slots["default"](); } }; }, };
如果在第一个条件那没有匹配到的话,肯定会到达第二个条件判断,也就是 if (slots["default"])
接着就是如果有 default slot 的话,那么就返回即可
至此,你已经实现了一个简单的 Switch 功能组件了
总结
让我们来总结总结你已经学到了哪些知识点
- 设计组件时,先设计该组件的规则(接口)
- tasking 的思想,把大功能拆小,然后逐一击破
- 在 vue3 中获取 slots 的方式
- setup 不止可以返回对象,还可以返回一个函数,效果同 render 函数一样
- render 函数返回的 vnode 最终会被渲染到 view 上
如果你学到的话,那么请用你的小手点个赞呗~~~
完整代码
// VSwitch.vue <script> export default { props: ["case"], setup(props, { slots }) { return () => { if (slots[props.case]) { return slots[props.case](); } if (slots["default"]) { return slots["default"](); } }; }, }; </script>
扩展思考
那其实这里实现的 switch 功能并不完整,如果说用户匹配满足多个条件呢?并且没有 break,那么我们是不是应该把匹配到的 template 都显示出来呢?
自己尝试一下实现看看?
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]