当使用 React Native 时,你将会在两个环境中运行 JavaScript 代码:
在模拟器和电话中:[JavaScriptCore]( http://trac.webkit.org/wiki/JavaScriptCore) 是 JavaScript 的引擎,能够驱动 Safari 和 web 视图。由于在 iOS 应用程序中没有可写的可执行的内存,它不用 JIT 运行。
使用 Chrome 调试时,它在 Chrome 本身中运行所有 JavaScript 代码,并且通过 WebSocket 与 Objective-C 交互。所以你正在使用 [V8]( https://code.google.com/p/v8/)。
虽然两个环境很相似,但是你可能会以触及一些矛盾而结束。将来我们很可能去尝试其他 JS 引擎,所以最好避免依赖任何运行时的细节。
React Native 附带许多 JavaScript 转换,使编写代码更愉快。如果你好奇的话,你可以查看[所有这些转换的实现](https://github.com/facebook/jstransform/tree/master/visitors)。这是完整的列表:
ES5
关键字:promise.catch(function() { });
ES6
箭头函数:
调用传播:Math.max(...array);
类:class C extends React.Component { render() { return
解构:var {isActive, style} = this.props;
迭代:for (var element of array) { }
计算属性:var key = 'abc'; var obj = {[key]: 10};
对象 Consise 方法:var obj = { method() { return 10; } };
对象 short 表示法:var name = 'vjeux'; var obj = { name };
其他参数:function(type, ...args) { }
模板: var who = 'world'; var str = 'Hello ${who}';
ES7
对象传播:var extended = { ...obj, a: 10 };
Trailing Comma 函数:function f(a, b, c,) { }
文章标题:创新互联React教程:JavaScript环境
网页网址:http://www.mswzjz.cn/qtweb/news35/346785.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能