Origin of Ray

一起探索互联网的秘密

之前一篇博客讲过React的更新过程,不过在那个博客中,任务调度使用的是浏览器的requestIdleCallback,而实际上React使用的自己实现的一个任务调度器,我们这次就开分析一下它的源码,以及React为什么要自己实现任务调度器。

本文基于React仓库中的16.18.6分支进行解读。

阅读全文 »

最近在leetcode上遇到了几个问题都是采用二分法来解决的,总结了一下其中的规律,简单来说,如果是要从有界区间中寻找符合条件的最大值或者最小值,可以考虑采用二分法,不过不是基础的二分法,而是不断寻找左侧边界或者右侧边界的二分法。

阅读全文 »

这几天遇到个问题,就是在vue-router嵌套子路由的时候,如果深层的router-view组件没有声明key,且路由配置中的component是函数式的组件,就会导致在router.push的时候无法更新。

对于函数式组件和函数式编程,需要了记得可以我之前的相关博客;

本文主要是分析vue-router的源码,vue-router的源码主要是两部分,第一部分是做路由匹配,第二部分是做路由跳转的,本文先主要关注第一部分

阅读全文 »

函数式编程和函数式组件是现在开发的一个趋势,过去一直在用,但是没有从概念上理解,本文就把二者放在一起总结一下并进行一定的对比。

函数式编程是一种编程范式,而函数式组件是这种范式下的一种产物。

阅读全文 »

我们接着上一篇博客继续总结和学习JavaScript的常用设计模式,这一次我们总结两个在JavaScript角度来讲比较像的模式,也就是代理模式,策略模式。

这两个模式在非函数式编程编程的语言中,如Java中区别是比较明显的,但是用JavaScript来看则是比较相似的。

阅读全文 »

上一篇博客我们介绍了Qiankun的沙盒机制,也就是不同的子应用之间是如何做环境隔离的,这篇博客我们就基于上一篇博客讲一下如何利用沙盒去进行子应用的加载和切换。

qiankun是基于single-spa实现的,所有内部用到了部分single-spa的接口,简单说一下single-spa和qiankun的区别,single-spa只做了子应用的注册,切换,路由监听等,还没有达到一个商用的水准,而qiankun在此之上加了js和css的沙箱隔离,按照官方文档,qiankun是达到了商用的要求。

阅读全文 »

为什么需要微前端

微前端其实诞生两个大的背景下,在提倡拥抱变化的前端社区可以看到新的框架、技术、概念层出不穷,并且随着WEB标准的演进,前端应用已经具备更好的性能、更快的开发效率。但随着而来的是应用的复杂程度更高、涉及的团队规模更广、更高的性能要求,应用复杂度已经成为阻塞业务发展的重要瓶颈。如何让现有系统拥抱最新技术提高生产力、并且解耦单体应用,是现在前端工程不得不面临的挑战。

阅读全文 »
0%