翻了翻这些年写过的博客,点点滴滴就像日记一样记录着自己的成长历程。上次写年终总结还是在2019年1月3日,写给2018......
2018,是从Android
转做前端的一个开始。
从接手一个小的前端功能模块,接触到了项目脚手架的概念,基于此了解到React
、Fusion
组件库。最先接触的dva
当中的connect
、mapStateToProps
、mapDispatchToProps
等等相关技术点是一脸蒙圈,只会照葫芦瓢实现基本功能,不敢有任何大胆的其他写法。
渐渐就会对接触到的任何技术点存留各种各样的问号,出于无尽的求知欲,就会知其然,也想知其所以然,一点点学习、积累、应用,总结。反反复复。
Redux说起
Redux
,一种数据管理方式。它的思想和核心源码都相对比较简单。一开始我有结合相关书籍和github
源码做过一次浅析《Redux》解读。
Redux
中通过store.dispatch
派发的action
,reducer
立即算出 state
,这叫做同步;action
发出以后,过一段时间再执行 reducer
,这样的异步改怎么样实现呢?
这就不得不提及中间件,中间件其实就是一个函数,对store.dispatch
方法进行了改造,在发出 action
和执行 reducer
这两步之间,添加了其他功能。
我读了两篇文章,受益匪浅。《中间件middleware》《中间件和异步操作》
redux-thunk
中间件,改写dispatch
,使得他可以接收函数入参。
redux-promise
中间件,改写dispatch
,使得它可以接收promise
入参。
但是这远远不够,你发现React和Redux各自为伍,如何让两位兄弟互帮互助,打工让我挣钱,早日让老板实现财富自由呢?
react-redux`就这样诞生了。《 The History and Implementation of React-Redux 》帮你了解它的实现和历史。
connect
函数可以将Redux
相关属性和方法注入组件中,你可以通过分发actions
注入数据和回调来改变数据。
// connect() is a function that injects Redux-related props into your component.
// You can inject data and callbacks that change that data by dispatching actions.
function connect(mapStateToProps, mapDispatchToProps) {
// It lets us inject component as the last step so people can use it as a decorator.
// Generally you don't need to worry about it.
return function (WrappedComponent) {
// It returns a component
return class extends React.Component {
render() {
return (
// that renders your component
)
}
componentDidMount() {
// it remembers to subscribe to the store so it doesn't miss updates
this.unsubscribe = store.subscribe(this.handleChange.bind(this))
}
componentWillUnmount() {
// and unsubscribe later
this.unsubscribe()
}
handleChange() {
// and whenever the store state changes, it re-renders.
this.forceUpdate()
}
}
}
}
继承和原型链
阅读《JavaScript
高级程序设计》,印象最深的是第六章——面向对象程序设计。颠覆了之前类继承的思维模式,深入了解了函数原型,原型继承的技术。再阅读MDN
的《继承和原型链》 加以巩固。这个内容很重要!很重要!很重要!
这里有我的《JavaScript高级程序设计》读书笔记
函数
一句“函数是一等公民”,勾起了我对它的无尽想象。
纯函数的最佳实践:redux
中的reducer
;
高阶函数最佳实践:闭包,Array
中map,reduce,filter,find,some,every
......
闭包的最佳实践:bind
、react-redux
中的connect
,redux
中间件
闭包
闭包一出,求知欲也呼之欲出。
《JavaScript高级程序设计》:闭包是指有权访问另一个函数作用域中的变量的函数。
MDN:函数和对其周围状态(lexical environment,词法环境)的引用捆绑在一起构成闭包(closure)。
闭包的第一个用途是使我们在函数外部能够访问到函数内部的变量。通过使用闭包,我们可以通过在外部调用闭包函数,从而在外部访问到函数内部的变量,可以使用这种方法来创建私有变量。
闭包的另一个用途是使已经运行结束的函数上下文中的变量对象继续留在内存中,因为闭包函数保留了这个变量对象的引用,所以这个变量对象不会被回收。
作用域
当你感觉充实的时候,作用域一词是否曾经波动了你的心弦。
作用域和执行环境是紧密联系在一起的。当代码在一个环境中执行时,会创建变量对象的一个作用域链。作用域链的用途是,保证对执行环境有权访问的变量和函数可以有序访问。如下图,在控制台就可以见到只闻其名不见其身的作用域
我有故事《理解JavaScript中的作用域》,你备酒。
学习了解XSS和CSRF、防抖和节流、HTTP和HTTPS、TCP三次握手/四次挥手、强缓存和协商缓存、defer和async。
优化是一个永恒的话题,首屏优化、性能优化、网络优化、webpack优化、react优化。
曾经我遇到一个面试题是,网页输入url,回车之后,不聊发生了什么。只聊各个环节优化的点和方法。
算法
工作了这么多年,算法其实都没有真正的深入学习过,只停留在冒泡排序终归说不过去。我开始跟随labuladong
的步伐进行了第一轮的学习,在github上做了相关的实践algorithm-javascript,同时在leetcode
上刷了一些相关的题目。
涉及到插入排序、希尔排序、选择排序、堆排序、冒泡排序、快速排序、归并排序、二叉树的深度优先遍历(前、中、后序遍历)、广度优先遍历、二叉搜索树
最后
写了印象深的一些东西,要去学习的有太多太多,2021继续加油!
要记得要去主动参加一些面试,在这个过程中真正检验你对各方面知识点的掌握程度,去发现不足。
认识自己很重要!