React Native && JSPatch

宏观认识


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. 底层实现:模块配置表




入门


0. Getting Started

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 源码




JSPatch 平台介绍


JSPatch – 动态更新iOS 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时刻处于可扩展可修改的状态。


JSPatch-实现原理详解

方法调用 -- 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))

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,658评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,482评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,213评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,395评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,487评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,523评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,525评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,300评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,753评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,048评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,223评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,905评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,541评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,168评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,417评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,094评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,088评论 2 352

推荐阅读更多精彩内容