最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 一次Vant tabs源码解析

    正文概述 掘金(KSHMR的小粉丝)   2021-01-21   1401

    1.找到源码的位置

    import {Tabs,Tab} from 'vant'
    import 'vant/lib/index.less'
    

    这是我们最熟悉的按需引入代码步骤了,那么在引入的过程中,会自动解析到node_modules中的 _vant@2.12.4@vant的es文件夹中,那么重点关注 tabs和tab这两个文件夹

    2.梳理tabs结构

    在tabs的index.js中,可以看到如下代码:

    一次Vant tabs源码解析

    这里体现了两个重要的函数 createComponentbem

    1.createComponent

    function install(Vue) { 
     var name = this.name;  Vue.component(name, this);  
     Vue.component(camelize("-" + name), this);
    } 
    
    export function createComponent(name) {  
        return function (sfc) {    
            if (isFunction(sfc)) {      
                sfc = transformFunctionComponent(sfc); // 转化成函数式组件    
            }    
            if (!sfc.functional) {      
                sfc.mixins = sfc.mixins || [];     
                sfc.mixins.push(SlotsMixin);    
            }    
            sfc.name = name;    
            sfc.install = install; // 这里的install实际上就是vant实现按需导入的关键    
            return sfc;  
      };}
    

    2.bem

    一次Vant tabs源码解析

    3.  render 函数

    对于render函数,官方是这么解释的:

    "Vue 推荐在绝大多数情况下使用模板来创建你的 HTML。然而在一些场景中,你真的需要 JavaScript 的完全编程的能力。这时你可以用渲染函数,它比模板更接近编译器"

    可以发现,render函数的性能要比我们平日书写的<template>性能要好,这也难怪vant会使用其编写Dom结构了。

    在了解Vue render函数之前,我强烈推荐你阅读这篇文档:渲染器 ,这能够使你对Vue渲染器的设计,以及实现有着更深刻的了解。(感谢大神的辛勤付出)

    接下来直接移步官方文档之 createElement参数 , 对需要传入的参数、格式有所了解后,来看看tabs中render的代码:

    一次Vant tabs源码解析

    【题外话:第一眼看到的时候,我直接靓仔语塞,这也太多太复杂了。。。但是,我从来就不是一个轻易就放弃的人,那就继续研究下去!当然我不建议直接看,我的思路是从实际渲染的DOM入手,一点一点去理解它生成的过程。】

    3. tabs DOM结构

    <van-tabs v-model="active">      
        <van-tab >内容 1</van-tab>      
        <van-tab >内容 2</van-tab>      
        <van-tab >内容 3</van-tab>      
        <van-tab >内容 4</van-tab> 
    </van-tabs>
    

    生成的DOM结构如下:

    一次Vant tabs源码解析

    1.wrap的生成过程

    一次Vant tabs源码解析

    如果你已经学习过之前的文档,那么你应该知道h函数是用来生成一个VNode节点的,相当于createElement函数,如图,我们可以知道Nav是通过遍历children(这里指van-tab) ,然后将children中所绑定的属性赋值给Title。那么问题来了,Title是什么类型?

    通过引入的title.js进行追踪,不难发现:

    一次Vant tabs源码解析

    oh,原来Title是个组件!首先看看render,可以发现this.genText()就是我们在vant-tab上绑定的title值,经过一番处理,最终会生成 <div><span>标签1</span></div>的DOM结构!

    那么最后,这个Nav所代表的,就是我们想要的导航栏,也就是我们在vant-tab上所绑定的title值。如图,我们可以看到,它最终会被一个wrap所包裹住。

    一次Vant tabs源码解析

    2. content的生成过程

    一次Vant tabs源码解析

    content也是个组件,但是它最终渲染出来的DOM只是<div class='van-tabs__content'></div>

    不免思考,那所写的内容哪去了呢?别忘了,这个标题叫做 【tabs 的DOM结构】,剩下的内容渲染,就在tab --> index.js 中进行~

    一次Vant tabs源码解析

    4.mixins

    在content.js中,可以看到vant使用了TouchMixin

    一次Vant tabs源码解析

    找到TouchMixin,如下:

    一次Vant tabs源码解析

    可以看到vant在这个mixin中,定义了我们常见的滑动函数,这就大幅度地提高了复用性。不禁引发一阵思考:以前我在封装函数的时候,会考虑用大量的js文件进行封装,一旦多了起来,会变难以维护。在单个页面需要对多个函数进行调用时,其实可以将这些通用的函数,放入到mixin中,有了mixin后,其实更方便了~

    5.总结

    其实tab谁都会做,但要做到像ui框架这种复用性极强,定义的API又很人性化,还需要仔细打磨,考虑多种情况才行。前人栽树,我在乘凉时,也想看看前人是如何 “栽树” 的~


    起源地下载网 » 一次Vant tabs源码解析

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元