搜索
您的当前位置:首页正文

React Native && JSPatch

来源:二三娱乐

宏观认识

他们实现了一套类似css的子集,用来解决样式问题,相当复杂和强大,靠这个才能将Native的核心组件组成JS层的基本组件再组成业务端的业务组件

JavaScriptCore,using div and a you use things like View andText

came from扯了一堆,讲了一堆 Native 不好的地方,迭代复杂,上手难。然后十多分才进入 RN,用的是Native的UI控件,底层用js调方法。

可以用chrome调试 构建iOS app的js代码。



源码解析

布局

JS/OC不会频繁通信,会在事件触发时批量传递,提高效率。

1.  JS-OC通信实际上很简单,OC向JS传信息,webview的-stringByEvaluatingJavaScriptFromString 方法可以直接在当前context上执行一段JS脚本,并且可以获取执行后的返回值,返回值就相当于JS向OC传递信息。

React Native也是以此为基础,通过各种手段,实现了在OC定义一个模块方法,JS可以直接调用这个模块方法并还可以无缝衔接回调。

举个例子,OC定义了一个模块RCTSQLManager,里面有个方法-query:successCallback:,JS可以直接调用RCTSQLManager.query并通过回调获取执行结果。

2. 底层实现:模块配置表


入门

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节点 - 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


实时修复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程序中的类型错误,以提高程序员的效率和代码质量。

这个坑最少找了几十种方法:

降级 == 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.

Props

Style

height + width

Layout - flexDirection(行 和 列),alignItems(分布方式,头,中,尾,around,between),justifyContent(第二坐标系,对应flexDirection,头,中,尾,stretch(不需要w或者h))

Top