React Native新手笔记(170330)

2017-03-30  本文已影响88人  waterwind

1.ES6标准下全局对象prototype修改后的引用问题

因为现在所有的引用都要借用export、import语句,但是全局对象(例如String)的prototype被修改后,总不能再export一个全局对象出去吧【而且加了export就会提示语法错误】。

解决方法如下

1)在a.js文件中定义= String.prototype.someFunction

2)在b.js文件里  import {} from 'a';

2.Object-C代码批量转RN的省时技巧(远远说不上方案)

最近在把之前做的iOS项目往RN上转,发现修改起代码真是烦不胜烦,特别是有些工作是重复劳动。在网上找了半天转换工具无果。只好自己想办法用正则表达式来批量替换。

显然没有办法做到一次到位,但通过这种方法,还是多少减轻了一些工作。这个方法的巧妙之处,是使用了EmEditor这个神编码器的批量替换功能。EmEditor在替换对话框上有一个“批处理”的按钮,点击之后就可以编辑一个批量替换列表。而这个列表呢,是可以导入导出的,因此可以在导出的tsv(table seperated values)文件中进行编辑,将要替换的内容一行行加上。例如以下两行:

on    ^-\s*\(.*?\)                    R

on     ^\+\s*\(.*?\)     static     R

on:表示本条策略打开,咱干这活,默认当然要全打开

接下来的正则表达式,是搜索匹配串,例如^-\s*\(.*?\)可以匹配

- (NSString*)  、     - (int)  ……

这自然在JS里是要删除的,所以替换为空值(到R字母,中间是一个tab,一个空格,一个tab)。后面的R则表示是否使用正则表达式,如果不想使用,就不要写R,留空就好;还有一个C表示大小写敏感,可根据情况使用。“CR”则可表示既区分大小写,又使用正则表达式。

上面例子的第二条,^\+\s*\(.*?\)可匹配 + (NSString*)  、    + (int)  ……,这种情况“翻译”成JS,是要变成Class里的静态函数,所以直接替换为Static。

以下是我对一些常见条目的替换方案【自己理解含义,我就不加注释了】,远远不够完善,替换后还要做许多工作。大家还可以根据自己工程的特色,替换自己的内容。

on ^-\s*\(.*?\) R

on ^\+\s*\(.*?\) static R

on :\(.*?\) ( R

on :\(.*?\)(.*?)\s \1, R

on :\(.*?\)(.*?)$ (\1) R

on ^#pragma //pragma R

on \[self\s(.*?)\] this.\1 R

on for\s\(int\s(i|j|k|m|n) for(let \1 R

on fmod\((.*?)\,(.*?)\) (\1) % (\2) R

on \[NSArray\sarrayWithArray:(.*?)\] Array.from(\1) R

on \[(\w+)\s+([^,]+?)\]; \1.\2; R

on ABS\( Math.abs( CR

on \.objectAtIndex: [ R

on \.count .length R

on MAX\( Math.max( CR

on @implementation(.*)$ export class\1{ R

on @end } R

上一篇下一篇

猜你喜欢

热点阅读