Awesome Open Source
Awesome Open Source

我的第一本书

为了获得更好的阅读体验,您可以访问在线版本

关于我

我是一个对技术充满兴趣的程序员, 擅长前端工程化,前端性能优化,前端标准化等。

做过.net, 搞过Java,现在是一名前端工程师。

除了我的本职工作外,我会在开源社区进行一些输出和分享,比较受欢迎的有leetcode题解前端面试宝典 - 图解前端

如果大家需要内推的可以找我,我这里有包括阿里,腾讯,头条,网易等很多公司的朋友。 有需要可以直接群里联系我,或者发送到我的个人邮箱 [[email protected]]。

我为什么要写这本书(序)

写这本书的目的很简单,就是审视自己。我喜欢用写作来总结自己的生活,因为花在这上面的时间是复时间,就像复利一样。我喜欢一个人散步,因为散步可以将思维释放,我认为做太多重复没有创造性的东西对我来说没有什么价值,我更喜欢将散步当做身心的一种放松,而且我很多好的想法都是在散步中得到的,它不仅能使你身体得到放松,而且可以让你工作效率翻倍。如果读书是知识的输入的话,那么写书就是对知识的输出。通过读书掌握的通常很少,据研究表面通常不到书内容的 10%。但是通过合适的输出,可以将这一比例上升到 32%。输出的方式不仅仅有写作,还有复述,讲给别人等等。

编程是一种技艺,一种需要用心学习的技艺

同时我想借这个机会认识一些志同道合的人,就是打算在这一行干点事,留下点东西的人。与人交流其实也是一种复利,通过思维的碰撞,可以将彼此的能量和创新得到有效的释放,同时也是审视自己的绝佳时机。

前言

这是我准备写的第一本书,其实早些时候已经打算开始写书了,只是苦于没有写书经验,无从下手。写书不同于博客,写书需要将知识,经验等系统化地讲述出来,而我现在恰巧缺乏这种表现能力。因此我决定在这里将项目中零散的东西记录下来,然后后期润色一下,写成一本书。

软件工程之所以叫工程是因为其中运用了很多工程化的方法。软件的构造应该是工程学科,早期的各种瀑布模型,UML 建模语言,以及近期的 SCRUM,他们中充斥着各种工程化的工具和方法。 知乎是这么描述软件工程的:软件工程 (Software Engineering) 是一门研究和应用如何以系统性的、规范化的、可定量的过程化方法去开发和维护软件,以及如何把经过时间考验而证明正确的管理技术和当前能够得到的最好的技术方法结合起来的学科。 想一想中世纪的大教堂,每一座都跨越数千人数年的努力,它们相信个人的力量支撑了整个项目:

我们,采集的只是石头,却必须时刻展望未来的大教堂。

本书主要分为四个部分来讲述软件开发的工程化。

  • 第一部分讲述前后端如何分离,旨在通过任务分工,拆解,提高单个成员的开发效率,并通过减少前后端沟通进而提高项目整体成员的开发效率。这一章主要讲述为什么要前后端分离的历史,为什么要前后端分离,如何做到前后端分离,以及前后端分离能够带来哪些好处。
  • 第二部分讲述模块化与组件化。高级语言有很多模块化的思想。比如高级语言中的类和实例,各种第三方库,前端的 web-components 等等。可以说模块化和组件化无处不在,那为什么还要花时间去讲述这些东西呢?记得大学时候学习 C#的时候老师讲过面向对象的四个基本特性是抽象,继承,封装和多态。其实面向对象正是软件开发早期对模块化和组件化的一种探索,是人类智慧的结晶。其实模块化和组件化是一种将复杂系统分解为更好的可管理模块的方式。这一章主要讲述模块化的发展,模块化在不同领域的表现,模块化给我们带来了什么,以及如何实现模块化。
  • 第三部分讲流程自动化。自动化的流程无疑可以减少人力成本,可以提高效率,降低失误率。自动化可以将人们从繁琐的无味的重复劳动中解脱出来。有人说程序员是懒惰的,因为它们经常编写一些可以减少日常工作的工具,从而达到”偷懒“ 的目的。这一章主要讲述流程自动化是一种什么样的感受,如何实现自动化,这一章主要分享我在实际工作中遇到的问题,以及自己在自动化方面作出的思考。
  • 第四部门主要讲述页面加载性能优化。 性能优化一直是一个非常古老,并且非常深奥的问题。说他古老是因为,我们的产品是让用户使用的,良好的用户体验是抓住用户内心的根本,因此性能优化方面,业界做了非常多的探索。说他非常深奥是因为没有任何一种优化手段可以 cover 全部, 这就需要你能够靠你的经验和眼界分辨现实情况,采取合适的优化方法和时机(不要过早优化)。这部分主要讲述 web 性能优化,从用户输入 URL 到页面加载出来,用户进行交互着手分析可以优化的点,并讲述如何发现系统性能的短板。 建立性能监控平台也是非常重要的一环,本章也会带你一步步拆解,讲述如何设计并开发一个性能监控平台。

第一章 前后端分离

第二章 模块化与组件化

第三章 流程自动化

第四章 页面加载性能优化

第五章 前端调试

第六章 到处都是测试

附录一 自动化小脚本

附录二 参考文献

关注我

我重新整理了下自己的公众号,并且我还给它换了一个名字脑洞前端,它是一个帮助你打开大前端新世界大门的钥匙 🔑,在这里你可以听到新奇的观点,看到一些技术尝新,还会收到系统性总结和思考。

在这里我会尽量通过图的形式来阐述一些概念和逻辑,帮助大家快速理解,图解是我的目标。

之后我的文章会同步到微信公众号 脑洞前端 ,你可以关注获取最新的文章,并和我进行交流。

另外你可以回复大前端进大前端微信交流群, 回复 leetcode 拉你进 leetcode 微信群,如果想加入 qq 群,请回复 qq。

gongzhonghao

交流群

现在还是初级阶段,需要大家的意见和反馈,为了减少沟通成本,我组建了交流群。大家可以扫码进入

QQ 群

qq-group-chat

微信群

JavaScript

(由于微信的限制,100个人以上只能邀请加入, 你可以添加我的机器人回复“大前端”拉你进群)

License

Apache-2.0


Get A Weekly Email With Trending Projects For These Topics
No Spam. Unsubscribe easily at any time.
automation (718
performance (610
components (297
roff (126
modules (92
front-end-development (58