宏观认识
1. What does Apple think of React Native ?
2.《如何评价 React Native?》:来自知乎的这个回答详细介绍了 Facebook 即将开源的 React Native 的相关知识,包括核心实现、设计考虑、以及 React Native 的优势和劣势。
他们实现了一套类似css的子集,用来解决样式问题,相当复杂和强大,靠这个才能将Native的核心组件组成JS层的基本组件再组成业务端的业务组件
2.5《First Impressions using React Native》:作者介绍了他使用 Facebook 即将开源的 React Native 的感受。
JavaScriptCore,using div and a you use things like View andText
3.《React.js Conf 2015 Keynote – Introducing React Native》:这是 Facebook 出品的 react.js 的视频介绍。Facebook 打算用它来统一移动端的编程语言,react.js 把界面全部用 native 控件实现,js 只作为后端逻辑层。Facebook 也打算开源该框架,如果这个框架成功,将改变整个业界的移动开发效率,因为 iOS 和 android 代码可以大部分复用。注:视频来自 youtube。
came from扯了一堆,讲了一堆 Native 不好的地方,迭代复杂,上手难。然后十多分才进入 RN,用的是Native的UI控件,底层用js调方法。
《React.js Conf 2015 Keynote 2 - A Deep Dive into React Native》
可以用chrome调试 构建iOS app的js代码。
4. 《跨平台开发时代的 (再次) 到来?》:这篇文章主要想谈谈最近又刮起的移动开发跨平台之风,并着重介绍和对比一下像是 Xamarin,NativeScript 和 React Native 之类的东西。
5. 一种跨平台的App开发解决方案 -- 设计上主要考虑的问题,对初学来说有点意思。
6. 也许,DOM 不是答案 -- Web App vs. Native App,为什么Web app有性能瓶颈?FlipBoard没有使用DOM,用canvas输出
源码解析
布局
《react-native 之布局篇》:天猫前端@横天同学对 css-layout 的布局能力做了一些实验,给出了一些有价值的结论,如:react 宽度基于pt为单位;flex能实现网格系统需求,且网格能够各种嵌套无bug;padding 设置在Text元素上所有padding变成了marginBottom...
JS/OC不会频繁通信,会在事件触发时批量传递,提高效率。
《React Native 通信机制详解》:React Native 是 facebook 刚开源的框架,可以用 javascript 直接开发原生 APP,先不说这个框架后续是否能得到大众认可,单从源码来说,这个框架源码里有非常多的设计思想和实现方式值得学习,本文介绍了它最基础的 JavaScript-ObjectC 通信机制。
1. JS-OC通信实际上很简单,OC向JS传信息,webview的-stringByEvaluatingJavaScriptFromString 方法可以直接在当前context上执行一段JS脚本,并且可以获取执行后的返回值,返回值就相当于JS向OC传递信息。
React Native也是以此为基础,通过各种手段,实现了在OC定义一个模块方法,JS可以直接调用这个模块方法并还可以无缝衔接回调。
举个例子,OC定义了一个模块RCTSQLManager,里面有个方法-query:successCallback:,JS可以直接调用RCTSQLManager.query并通过回调获取执行结果。
2. 底层实现:模块配置表
入门
1.《React 入门实例教程》:React 起源于 Facebook 的内部项目,因为该公司对市场上所有 JavaScript MVC 框架,都不满意,就决定自己写一套,用来架设 Instagram 的网站。本文是阮一峰原创的入门教程。
ReactDOM.render()
JSX 语法 - JSX使得你在代码当中编写标记语言,HTML 与 JavaScript 的混写
基本语法规则:遇到 HTML 标签(以<开头),就用 HTML 规则解析;遇到代码块(以{开头),就用 JavaScript 规则解析。
React.createClass - 注意,组件类的第一个字母必须大写,否则会报错。组件类只能包含一个顶层标签,否则也会报错。
添加组件属性,class属性需要写成className,for属性需要写成htmlFor,这是因为class和for是 JavaScript 的保留字。
React.Children.map来遍历子节点,this.props.children表示组件的所有子节点,(1) undefined (2) object (3) array
组件类的PropTypes属性,就是用来验证组件实例的属性是否符合要求
getDefaultProps方法可以用来设置组件属性的默认值。
组件并不是真实的 DOM 节点,而是存在于内存之中的一种数据结构,叫做虚拟 DOM (virtual DOM)。只有当它插入文档以后,才会变成真实的 DOM 。根据 React 的设计,所有的 DOM 变动,都先在虚拟 DOM 上发生,然后再将实际发生变动的部分,反映在真实 DOM上,这种算法叫做DOM diff,它可以极大提高网页的性能表现。
真实的DOM节点 - ref属性,由于 this.refs.[refName] 属性获取的是真实 DOM ,所以必须等到虚拟 DOM 插入文档以后,才能使用这个属性,否则会报错。
this.state 状态机,this.props表示那些一旦定义,就不再改变的特性,而this.state是会随着用户互动而产生变化的特性
<input type="text" value={value} onChange={this.handleChange} />,不能用props,要用事件回调 event.target.value 读取用户输入。
组件的生命周期,- will & did
Mounting:已插入真实 DOM
Updating:正在被重新渲染
Unmounting:已移出真实 DOM
Ajax
{{}} == 这是因为React 组件样式是一个对象,所以第一重大括号表示这是 JavaScript 语法,第二重大括号表示样式对象。
2. HackerNews-React-Native:HackerNews-React-Native 是用 React Native 完成的 HackerNews 客户端。
3. f8Conf-React-Native: 2016 官方F8 app 源码
实时修复Bug,动态运营,动态增加功能
JSPatch用iOS内置的JavaScriptCore.framework作为JS引擎,但没有用它JSExport的特性进行JS-OC函数互调,而是通过Objective-C Runtime,从JS传递要调用的类名函数名到Objective-C,再使用NSInvocation动态调用对应的OC方法。
JSPatch和wax一样都是通过OC Runtime的接口通过字符串反射找到对应的类和方法进行调用,这中间的字符串处理会损耗一定的性能,另外两种语言间的类型转换也有性能损耗
所以动态添加业务模块目前还是推荐尝试React Native,但React Native并不会提供原生OC接口的反射调用和方法替换,无法做到修改原生代码,JSPatch以小巧的引擎补足这个缺口,配合React Native用统一的JS语言让一个原生APP时刻处于可扩展可修改的状态。
方法调用 -- OC runtime ( 类名/方法名 -> 类和方法,替换实现,动态添加类+方法+注册)
JSPatch 基本原理:JS 传递字符串给 OC,OC 通过 Runtime 接口调用和替换 OC 方法。
require
踩坑
nuclide + react + ES2015 + Redux
atom -> nuclide
react -- 27876 total
安装:
- node是基于Chrome V8引擎的Javascript运行环境。
- watchman是 facebook 的一个开源项目,用来监视文件并且记录文件的改动情况,当文件变更它可以触发一些操作,例如执行一些命令等等。
- flow同样是facebook的一个开源项目,是Javascript的静态类型检查器,用于发现JS程序中的类型错误,以提高程序员的效率和代码质量。
<1>Node.js not linked error- 加权限 sudo chown -R $(whoami) /usr/local,再 brew link --overwrite node
<2>npm ERR! fetch failedhttp://registry.cnpmjs.org/react-native-cli/download/react-native-cli-1.0.0.tgz
这个坑最少找了几十种方法:
npm config set registryhttps://registry.npm.taobao.org
npm config set disturlhttps://npm.taobao.org/dist
<3> react-native init xxx 卡住不动 --React-Native init 失败
降级 == sudo npm install -g npm@2.14.6
<4> could not connect to development server.
running npm startfrom react-native directory
Run npm starton local machine to start the development server. React Native relies on a development server to communicate with the app running in the simulator.
<5> 用 main.bundle 就是 Unable to execute JS call: __fbBatchedBridge is undefined.
用 url 就是 Could not connect to development server.
this page has a good overview of ES2015 features.
Props
State - You can also use a state container like Redux to control your data flow.
Style
height + width
Layout - flexDirection(行 和 列),alignItems(分布方式,头,中,尾,around,between),justifyContent(第二坐标系,对应flexDirection,头,中,尾,stretch(不需要w或者h))