前言
当今,前端应用需要解决的业务场景正变得越来越复杂,这也直接推动了前端技术的迅速发展,各种框架和类库日新月异、层出不穷。面对众多的框架和类库,前端开发者可能感到眼花缭乱,但换一个角度来看,这未尝不是一种百家争鸣的现象。不同框架和类库的设计思想和设计理念各有千秋,解决的问题也有所不同,这些多元化和差异化不断推动前端技术的发展,同时也是前端技术领域的一份思想瑰宝。
React作为当今众多新技术的一个代表,由Facebook开源,致力于解决复杂视图层的开发问题,它提出一种全新的UI组件的开发理念,降低了视图层的开发复杂度,提高了视图层的开发效率,让页面开发变得简单、高效、可控。此外,React不仅是单一的类库,更是一个技术栈生态,可以和生态中的Redux、MobX等其他技术结合使用,构建可扩展、易维护、高性能的大型Web应用。
本书内容
本书涵盖React技术栈中的主要技术,内容由浅到深。本书内容分为基础篇、进阶篇和实战篇,每一篇内容又分成若干章节来介绍。
基础篇,介绍了React的基本概念,包括React的开发环境和开发工具、React的基本用法和React 16的新特性。每个知识点都有配套的项目示例。
进阶篇,深入介绍了React的几个重要概念,如组件state、虚拟DOM、高阶组件等,此外,还针对初学者使用React时容易产生困惑的知识点做了专门讲解,如组件与服务器通信、组件之间通信、组件的ref属性等。
实战篇,介绍了React技术栈中最重要的三个技术:React Router、Redux和MobX,每一个技术都配有详细的项目实战示例。
本书章节的难度逐步递增,各章节的知识存在依赖关系,所以读者需按照章节顺序阅读本书,不要随意跳跃章节,尤其是在阅读实战篇时,务必保证已经掌握了基础篇和进阶篇的内容,否则,阅读实战篇可能会有些吃力。
本书特点
本书的特点是内容全、知识新、实战性强。
内容全:本书不仅详细介绍了React的使用,还详细介绍了React技术栈中最常用的其他相关技术:React Router、Redux和MobX。
知识新:本书介绍的知识点都是基于各个框架、类库当前的最新版本,尤其是涵盖React 16的新特性和React Router 4的介绍。对于新版本已经不再支持或建议废弃的特性,本书不会再介绍,确保读者所学知识的时效性。
实战性强:本书配有大量示例代码,保证读者学以致用。实战篇使用的简易BBS项目示例接近真实项目场景,但又有所简化,让读者既可以真正理解和领会相关技术在真实项目中的使用方式,又不会因为示例项目过于复杂而影响学习。
本书目标读者
本书面向希望从零开始学习React的初学者,或者已经有一些React使用经验,希望更加全面、深入理解React技术栈的开发人员。
示例代码
本书的示例代码下载地址为https://github.com/xuchaobei/react-book。如果读者发现代码或者书中的错误,可以直接在该代码仓库提交issue。
本书中默认的开发环境是Node.js v8.4.0,书中介绍到的几个主要库的版本分别为React 16.1.1、React Router 4.2.2、Redux 3.7.2及MobX 3.3.1。
致谢
本书的完成离不开在各个方面给过我支持和帮助的人,请允许我在这里向他们表示感谢。
首先,感谢公司的领导余海峰(Colin)和贺鸣(Sky)对我写书的支持。Colin在百忙之中还抽出时间为本书作序。
其次,感谢我的同事王博、陈小梦、吴福城、詹敏和朱雅琴,他们给本书提出了很多宝贵的意见。
还要感谢我的老婆,2017年,她的新书《时间的格局:让每一分钟为未来增值》出版,这也让我产生了写书的念头,同时她的写书经验也给了我很多帮助。
最后,感谢清华大学出版社的王金柱老师,正是缘于他的主动联系,才让我写书的念头变成了行动。他认真、负责的工作态度也保证了本书的顺利问世。
联系作者
欢迎各位读者通过我的微信订阅号:老干部的大前端(ID:Broad_FE)和我进行沟通交流,订阅号还提供了更多的大前端学习资源。读者可以扫描下方二维码关注订阅号。
徐 超
2018年1月1日于上海