透传是什么意思(华为蓝牙耳机透传是什么意思)

透传是一个通讯层面的概念,指的是在通讯中不管传输的业务内容如何,只负责将传输的内容由源地址传输到目的地址,而不对业务数据内容做任何改变。其实 透传 这个概念,我

透传是一个通讯层面的概念,指的是在通讯中不管传输的业务内容如何,只负责将传输的内容由源地址传输到目的地址,而不对业务数据内容做任何改变。

其实 透传 这个概念,我最早是从上面一个领导那里听到的,由于他是电气工程师出身,而硬件通讯这块用到透传还是挺多的。

当我听到 透传 这个词后,我感觉有那么一点熟悉感,仔细想想后我发现,其实我们前端也一直在使用透传,特别是在做基础封装时。

透传在前端的应用

今天就用一个 Vue基础组件封装 的过程为例,来简单聊聊什么是透传。

相信不少前端er做项目都会用到组件库,是ElementUI还是Ant Design,这都不重要。然后我们又希望在第三方组件库的基础上再做一点点定制。

举个例子, el-button 有个属性是 size ,用于控制按钮组件的尺寸。

可以看到,默认size是比较大的。然而我们设计师基于组件库出自己的设计方案时,其实选择的默认按钮尺寸可能恰好对应 ElButton 的 medium 尺寸,或者是其他值。这样一来,如果我不对 el-button 做封装,每个使用 el-button 的地方都要多写一个属性 size ,类似于这样:

很明显,每使用一次 el-button ,我就要写一个 size 属性,好烦啊!

是的,确实很烦,那么怎么解决呢?答案是提供一个编程接口,去改变组件的默认值。有这方面考虑的组件设计者一般会提供一个设置默认值的接口,比如 xxx.setDefault(options) 。那么ElementUI和Ant Design有没有提供这样的能力呢?据我观察好像是没有,其实主要是因为Vue没有一个方便的途径去修改 prop 的 default 属性。但是没有方便的途径并不代表没有途径…

由于本文的主题是 透传 ,所以就不说那个途径(或者说方法)了,有点跑偏了。

网友小王说:“好,那就硬上,封装一个组件!”

好的,马上安排!基本思路是封装一个自定义组件,组件里面再调用 el-button ,并且强行给 el-button 安排上默认属性 size=”medium” 。

聪明的读者一看就发现了,这个组件问题很大,除了size属性, ElButton 的其他属性和事件怎么处理完全没有提到!

小王说:“没事,您需要什么?我给安排上!”

于是,这个组件最后就慢慢变成了:

看起来有点糟心,这组件甚至会更冗余,更复杂,因为我这里只加了3个prop和1个event。对于稍微复杂一点的组件来说,prop加上event一共几十个是随随便便的吧!你适配得过来吗?而且,不少人还有代码洁癖吧,这简直受不了!

淡定淡定!这当然是有办法解决的。强如框架的设计者尤小右自然早已想到了这个场景,所以你应该在Vue官网文档中关注到 inheritAttrs 。

如何理解 inheritAttrs (默认值为 true )这个选项呢?我们知道,一个组件如果要接受父组件传来的属性,是需要先在 props 里面预定义好的。比如前面的例子,我在 MyButton 预定义了3个属性,分别是 size , type , disabled ,意思是 MyButton 这里只接受3个 prop 。

那么假设父组件传了4个或者更多 prop 过来呢,会怎么样?看下面这个例子:

实际上, round 和 autofocus 都不是 MyButton 组件支持的 prop ,所以反映到 HTML 上是这么一个效果:

作为使用者,我们应该是希望 round 和 native-type=”submit” 能够传到 el-button ,产生应有的效果。然而, round 和 native-type=”submit” 仅仅是挂在了根元素的 attribute 上,并没有真正起到应有的作用!

举个例子, round 属性作用到 el-button 能让 button 带一个 is-round 的 class ,从而产生圆角效果!

也就是说, inheritAttrs 的作用是:使那些没有在 props 中定义的属性,直接以 attribute 的形式作用在组件的根元素上!

那么 round 和 native-type=”submit” 如何透传下去呢?

首先,不能让那些未被props标识的属性直接落到根元素上,所以需要设置 inheritAttrs 为 false 。

然后,要获取到那些未被props标识的属性,并直接绑定到 el-button 。恰好,Vue提供了 attrs 用于获取这些属性,而 v-bind 本身就能绑定一个对象,这是容易被我们忽略的!

处理完属性透传,接下来我们还要处理事件,类似于 $attrs , $listeners 也能把父组件中对子组件的事件监听全部拿到,这样我们就能用一个 v-on 把这些来自于父组件的事件监听传递到下一级组件。

看图可能会更好理解!

相当于 MyButton 是一个 不赚差价的中间商 ,直接透传消息!直观上看,组件代码量有一个明显的减少,更重要的是扩展性和可维护性变得更强!

对于调用者来说,使用体验是完全没有被影响的,他的感觉就好像仍然在直接使用 el-button ,属性传递和事件监听的使用体验都没有任何变化!

总结

结合 inheritAttrs , v-bind 以及 v-on ,我们就实现了一个支持透传的基础组件!本文是以 Button 组件为例,做的关于透传的入门介绍。实际上,透传的应用范围远远不止 Button 组件,利用透传的技巧,我们能做更多漂亮的事情!现在,你的代码洁癖还好吗?

本文转载网络分享,文章版权归作者所有:

免责声明:部分文章是来自大数据AI进行生成,内容仅供学习参考,不承认相关法律责任。如果您发现本站中有涉嫌抄袭或不准确地方的内容,请发送邮件至:glmpjh@163.com进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。

(0)
上一篇 2023年9月18日 上午3:21
下一篇 2023年9月18日 上午3:27

相关推荐

  • 2025南昌大学医学院怎么样

    以下是关于南昌大学医学院的综合分析,涵盖办学层次、全国排名、优势专业、录取分数线、学生口碑及院校介绍等关键信息,采用高曝光文案结构并附表格整理:南昌大学医学院(对外称南昌大学江西医学院)是江西省医学教育的核心基地,前身为1921年成立的江西

    问答 2025年4月26日
  • 2025年沧州职业学院怎么样

    2025年沧州职业技术学院综合评测报告院校概况沧州职业技术学院是经河北省人民政府批准建立的全日制普通高等职业院校,位于河北省沧州市。学院始建于1958年,2000年由沧州工业学校、沧州农业学校和沧州农林科学院合并组建而成,2011年又整

    问答 2025年5月19日
  • 黑纱裙搭配什么鞋子(黑纱裙怎么搭配鞋子)

    黑纱裙是女性们常见的搭配单品之一,不仅轻盈、优雅,而且拥有极高的百搭能力。对于搭配黑纱裙的鞋子,不同的鞋子款式和颜色都能给人不同的视觉感受。那么今天,我们就来探讨一下黑纱裙搭*鞋子…

    问答 2024年1月11日
  • 郑州财税金融职业学院怎么样好不好,就业率怎么样?

    1、郑州财税金融职业学院怎么样郑州财税金融职业学院是河南省政府批准成立的一所专科层次的普通公办高等职业院校位于郑州市管城回族区。学院办学设施完善校园环境优美交通

    问答 2024年2月21日
  • 什么是大男子主义(什么是大男子主义表现)

    今天为大家介绍一种新类型的男性人格——大男子主义。大男子主义是以男性为主导而非以女性为主导,并且经常以男性标准来衡量一个女性自我评价是否成功时所表现出来的强烈情绪反应。大男子主义是…

    问答 2023年7月21日
  • 男生怎么变帅简单方法,青春期越长越帅的方法小技巧(男生怎么变帅简单方法)

    看到这个标题,肯定有老铁觉得栗子要带货恰饭了。但是——请放心,本期文章纯分享,可放心食用!变帅的好处就不用栗子多说了吧?就和你喜欢美女一样,大多数的女生也喜欢

    问答 2023年9月17日
  • 称号是什么意思(不愧于这个称号是什么意思)

    称号是指由某个团体或组织颁发的特殊荣誉或称谓,通常是为了表彰个人或团队在某个领域或方面所取得的杰出成就,或者是在特定场合下表现出的优异表现。在不同的场合和文化背景中,称号的含义和赋…

    问答 2023年10月3日
  • 代发是什么意思(邮件代发是什么意思)

    代发通俗来讲就是代理人或第三方代表客户去完成某项任务或行动。在商业领域中,代发经常应用于物流配送、薪资代发、*等方面。 代发的主要特点是便捷、快速、可信、安全。在物流配送领域,代发…

    问答 2023年7月22日
  • 闭是什么意思(闭关是什么意思)

    闭是一个汉字,读音为bì,意味着关闭、关门或封锁。在现代汉语中,闭通常在动词或形容词中使用,用于描述一个物品或场景被关闭或封锁。例如,关闭门窗、封锁边境等。 在文学和诗歌中,闭也经…

    问答 2023年12月19日
  • 2025年上外的卓越学院怎么样

    2025年上海外国语大学卓越学院全面解析 1. 办学层次与院校介绍卓越学院成立于2015年,是上外针对优秀本科生设立的荣誉学院,以“格高志远,追求卓越”为宗旨,培养兼具中国情怀与国际视野的复合型人才。学院依托上外强大的多语种学科(

    问答 2025年5月14日

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注