React Native es6 syntax_javascript スキルの詳細な分析
React native uses es6 directly to write code. Many new syntaxes can improve our work efficiency
Destructuring assignment
var { StyleSheet,Text,View } = React;
This code is the new destructuring assignment statement in ES6. Allows you to obtain multiple properties of an object and assign them to multiple variables using a single statement.
The above code is equivalent to:
var StyleSheet = React.StyleSheet; var Text = React.Text; var View = React.View
Look at a few more examples. In the past, to assign a value to a variable, you could only specify the value directly:
var a = 1; var b = 2; var c = 3;
And ES6 allows writing like this:
var [a, b, c] = [1, 2, 3];
For more details, please refer to: Destructuring and Assignment of Variables
Arrow function
Similar codes often appear in React Native:
The new arrow operator => in ES6 simplifies the writing of functions. The left side of the operator is the input parameters, while the right side is the operation performed and the returned value Inputs=>outputs
Cite a few chestnuts to feel it:
var array = [1, 2, 3]; //传统写法 array.forEach(function(v, i, a) { console.log(v); }); //ES6 array.forEach(v => console.log(v)); var sum = (num1, num2) => { return num1 + num2; } //等同于: var sum = function(num1, num2) { return num1 + num2; };
Please Google for more details, or check: https://www.imququ.com/post/arrow-function-in-es6.html
Spread operator
The … operator (also called the spread operator) is already supported by ES6 arrays. It allows passing arrays or array-like functions directly as parameters of functions without going through apply.
var people=['Wayou','John','Sherlock']; //sayHello函数本来接收三个单独的参数人妖,人二和人三 function sayHello(people1,people2,people3){ console.log(`Hello ${people1},${people2},${people3}`); } //但是我们将一个数组以拓展参数的形式传递,它能很好地映射到每个单独的参数 sayHello(...people);//输出:Hello Wayou,John,Sherlock //而在以前,如果需要传递数组当参数,我们需要使用函数的apply方法 sayHello.apply(null,people);//输出:Hello Wayou,John,Sherlock
In React, the spread operator is generally used for batch assignment of attributes. In JSX, you can use the ... operator to merge the key-value pair of an object with the props attribute of ReactElement.
var props = {}; props.foo = x; props.bar = y; var component = <Component {...props} />; //等价于 var props = {}; props.foo = x; props.bar = y; var component = <Component foo={x} bar={y} />; 它也可以和普通的XML属性混合使用,需要同名属性,后者将覆盖前者: JavaScript var props = { foo: 'default' }; var component = <Component {...props} foo={'override'} />; console.log(component.props.foo); // 'override'
More details: https://facebook.github.io/react/docs/jsx-spread.html
class
ES6 added support for classes and introduced the class keyword (in fact, class has always been a reserved word in JavaScript, the purpose is to consider that it may be used in new versions in the future, and now it finally comes in handy) . JS itself is object-oriented, and the classes provided in ES6 are actually just wrappers for the JS prototype pattern. Now that native class support is provided, object creation and inheritance are more intuitive, and concepts such as parent class method invocation, instantiation, static methods, and constructors are more visual.
class PropertyView extends Component { render() { return ( <View></View> ) } } //等价于 var PropertyView = React.createClass({ render() { return ( <View></View> ) } })
Method definition
In ECMAScript 6, a new syntax sugar called method definition is introduced. Compared with the previous complete writing method, this abbreviation allows you to write one less function key word.
React.createClass({ render() { return ( <View></View> ) } }) //等价于 React.createClass({ render : function() { return ( <View></View> ) } })
Finally, I recommend an ES6 PPT, which is well written: http://khan4019.github.io/ES6/
React native uses es6 directly to write code. Many new syntaxes can improve our work efficiency
Destructuring assignment
var { StyleSheet, Text, View } = React;
This code is the new destructuring assignment statement in ES6. Allows you to obtain multiple properties of an object and assign them to multiple variables using a single statement.
The above code is equivalent to:
var StyleSheet = React.StyleSheet; var Text = React.Text; var View = React.View
Look at a few more examples. In the past, to assign a value to a variable, you could only specify the value directly:
var a = ; var b = ; var c = ;
And ES allows writing like this:
var [a, b, c] = [, , ];
For more details, please refer to: Destructuring and Assignment of Variables
Arrow function
Similar codes often appear in React Native:
The new arrow operator => in ES6 simplifies function writing. The left side of the operator is the input parameters, while the right side is the operation performed and the returned value Inputs=>outputs
Cite a few chestnuts to feel it:
var array = [, , ]; //传统写法 array.forEach(function(v, i, a) { console.log(v); }); //ES array.forEach(v => console.log(v)); var sum = (num, num) => { return num + num; } //等同于: var sum = function(num, num) { return num + num; };
Please Google for more details, or check: https://www.imququ.com/post/arrow-function-in-es6.html
Spread operator
The … operator (also called the spread operator) is already supported by ES6 arrays. It allows passing arrays or array-like functions directly as parameters of functions without going through apply.
var people=['Wayou','John','Sherlock']; //sayHello函数本来接收三个单独的参数人妖,人二和人三 function sayHello(people,people,people){ console.log(Hello ${people},${people},${people}); } //但是我们将一个数组以拓展参数的形式传递,它能很好地映射到每个单独的参数 sayHello(...people); //输出:Hello Wayou,John,Sherlock //而在以前,如果需要传递数组当参数,我们需要使用函数的apply方法 sayHello.apply(null,people); //输出:Hello Wayou,John,Sherlock 而在React中,延展操作符一般用于属性的批量赋值上。在JSX中,可以使用…运算符,表示将一个对象的键值对与ReactElement的props属性合并。 var props = {}; props.foo = x; props.bar = y; var component = <Component {...props} />; //等价于 var props = {}; props.foo = x; props.bar = y; var component = <Component foo={x} bar={y} />;
It can also be mixed with ordinary XML attributes. An attribute with the same name is required, and the latter will override the former:
var props = { foo: 'default' }; var component = <Component {...props} foo={'override'} />; console.log(component.props.foo); // 'override'
更多详细信息:https://facebook.github.io/react/docs/jsx-spread.html
class
ES6中添加了对类的支持,引入了class关键字(其实class在JavaScript中一直是保留字,目的就是考虑到可能在以后的新版本中会用到,现在终于派上用场了)。JS本身就是面向对象的,ES6中提供的类实际上只是JS原型模式的包装。现在提供原生的class支持后,对象的创建,继承更加直观了,并且父类方法的调用,实例化,静态方法和构造函数等概念都更加形象化。
class PropertyView extends Component { render() { return ( <View></View> ) } } //等价于 var PropertyView = React.createClass({ render() { return ( <View></View> ) } })
方法定义(method definition)
ECMAScript 6中,引入了一种名叫方法定义(method definition)的新语法糖,相对于以前的完整写法,这种简写形式可以让你少写一个function键字.
React.createClass({ render() { return ( <View></View> ) } }) //等价于 React.createClass({ render : function() { return ( <View></View> ) } })
以上是小编给大家分享的react native es6语法,希望大家喜欢。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











JavaScript文字列置換法とFAQの詳細な説明 この記事では、javaScriptの文字列文字を置き換える2つの方法について説明します:内部JavaScriptコードとWebページの内部HTML。 JavaScriptコード内の文字列を交換します 最も直接的な方法は、置換()メソッドを使用することです。 str = str.replace( "find"、 "置換"); この方法は、最初の一致のみを置き換えます。すべての一致を置き換えるには、正規表現を使用して、グローバルフラグGを追加します。 str = str.replace(/fi

楽なWebページレイアウトのためにjQueryを活用する:8本質的なプラグイン jQueryは、Webページのレイアウトを大幅に簡素化します。 この記事では、プロセスを合理化する8つの強力なjQueryプラグイン、特に手動のウェブサイトの作成に役立ちます

それで、あなたはここで、Ajaxと呼ばれるこのことについてすべてを学ぶ準備ができています。しかし、それは正確には何ですか? Ajaxという用語は、動的でインタラクティブなWebコンテンツを作成するために使用されるテクノロジーのゆるいグループ化を指します。 Ajaxという用語は、もともとJesse Jによって造られました

10の楽しいjQueryゲームプラグインして、あなたのウェブサイトをより魅力的にし、ユーザーの粘着性を高めます! Flashは依然としてカジュアルなWebゲームを開発するのに最適なソフトウェアですが、jQueryは驚くべき効果を生み出すこともできます。また、純粋なアクションフラッシュゲームに匹敵するものではありませんが、場合によってはブラウザで予期せぬ楽しみもできます。 jquery tic toeゲーム ゲームプログラミングの「Hello World」には、JQueryバージョンがあります。 ソースコード jQueryクレイジーワードコンポジションゲーム これは空白のゲームであり、単語の文脈を知らないために奇妙な結果を生み出すことができます。 ソースコード jquery鉱山の掃引ゲーム

記事では、JavaScriptライブラリの作成、公開、および維持について説明し、計画、開発、テスト、ドキュメント、およびプロモーション戦略に焦点を当てています。

このチュートリアルでは、Ajaxを介してロードされた動的なページボックスの作成を示しており、フルページのリロードなしでインスタントリフレッシュを可能にします。 JQueryとJavaScriptを活用します。カスタムのFacebookスタイルのコンテンツボックスローダーと考えてください。 重要な概念: ajaxとjquery

このJavaScriptライブラリは、Cookieに依存せずにセッションデータを管理するためにWindow.nameプロパティを活用します。 ブラウザ全体でセッション変数を保存および取得するための堅牢なソリューションを提供します。 ライブラリは、セッションの3つのコア方法を提供します

このチュートリアルでは、jQueryを使用して魅惑的な視差の背景効果を作成する方法を示しています。 見事な視覚的な深さを作成するレイヤー画像を備えたヘッダーバナーを構築します。 更新されたプラグインは、jQuery 1.6.4以降で動作します。 ダウンロードしてください
