美文网首页
React Native新手笔记(170330)

React Native新手笔记(170330)

作者: waterwind | 来源:发表于2017-03-30 00:38 被阅读88次

    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

    相关文章

      网友评论

          本文标题:React Native新手笔记(170330)

          本文链接:https://www.haomeiwen.com/subject/gqquottx.html