成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

[譯]在 React.js 中使用 ES6+

Enlightenment / 2845人閱讀

摘要:如果是在中,我們也許只能這樣做但是,在中,我們不僅可以在對象字面量屬性的定義中使用表達(dá)式,還有使用使用字符串模板析構(gòu)擴(kuò)展運算符我們在編寫組件的過程中,經(jīng)常遇到要從父組件要把自己的很多屬性多傳給子組件的情況。

原文地址: http://babeljs.io/blog/2015/06/07/react-on-es6-plus/

在今年對 Instagram Web 進(jìn)行全新的設(shè)計的時候,我喜歡在寫 React 組件的時候,用上一些 ES6+ 的新特性。請允許我列舉這些能夠改變你寫 React 應(yīng)用方式的新特性。比起以往,這些特性能夠使你擼起碼來更加容易、有趣!

類(Class)

使用 ES6+ 來編寫 React 組件最明顯的變化就是我們定義組件(類)的語法的方式。我們可以用定義一個繼承了 React.Component 的ES6 類來代替原本使用 React.createClass 的來創(chuàng)建類的方式:

class Photo extends React.Component {
  render() {
    return ;
  }
}

我們可以發(fā)現(xiàn)這種寫法使得定義組件的方式變得更加簡潔:

// The ES5 way
var Photo = React.createClass({
  handleDoubleTap: function(e) { … },
  render: function() { … },
});
// The ES6+ way
class Photo extends React.Component {
  handleDoubleTap(e) { … }
  render() { … }
}

這樣我們可以少寫一對圓括號、一個分號、每個方法的冒號和 function 關(guān)鍵字。

所有生命周期方法都可以采用這種方式來定義。 但是 componentWillMount 還可以用 constructor 來代替:

// The ES5 way
var EmbedModal = React.createClass({
  componentWillMount: function() { … },
});
// The ES6+ way
class EmbedModal extends React.Component {
  constructor(props) {
    super(props);
    // Operations usually carried out in componentWillMount go here
  }
}
屬性初始化(property initializers)

在 ES6+ 類中,屬性類型 prop type 和默認(rèn)屬性 default prop 可以通過類中的 static 來聲明。同時,組件的初始狀態(tài)( initial state )可以通過 ES7 的屬性初始化(property initializers)來完成:

// The ES5 way
var Video = React.createClass({
  getDefaultProps: function() {
    return {
      autoPlay: false,
      maxLoops: 10,
    };
  },
  getInitialState: function() {
    return {
      loopsRemaining: this.props.maxLoops,
    };
  },
  propTypes: {
    autoPlay: React.PropTypes.bool.isRequired,
    maxLoops: React.PropTypes.number.isRequired,
    posterFrameSrc: React.PropTypes.string.isRequired,
    videoSrc: React.PropTypes.string.isRequired,
  },
});
// The ES6+ way
class Video extends React.Component {
  static defaultProps = {
    autoPlay: false,
    maxLoops: 10,
  }
  static propTypes = {
    autoPlay: React.PropTypes.bool.isRequired,
    maxLoops: React.PropTypes.number.isRequired,
    posterFrameSrc: React.PropTypes.string.isRequired,
    videoSrc: React.PropTypes.string.isRequired,
  }
  state = {
    loopsRemaining: this.props.maxLoops,
  }
}

ES7 中在構(gòu)造函數(shù)( constructor )下的屬性初始化操作中的 this 指向的是類的實例,所以初始狀態(tài)( initial state )可以通過 this.prop (即傳入的參數(shù))來設(shè)定。

箭頭函數(shù)(Arrow function)

React.createClass 方法在你的組件上做了一些額外的綁定工作,以確保在組件實實例的方法內(nèi)部, this 指向的是組件實例自身。

// Autobinding, brought to you by React.createClass
var PostInfo = React.createClass({
  handleOptionsButtonClick: function(e) {
    // Here, "this" refers to the component instance.
    this.setState({showOptionsModal: true});
  },
});

由于我們使用 ES6+ 的語法定義類的時候沒有采用 React.createClass 的方式,所以,這樣看來我們不得不手動來綁定這些方法中 this 的指向:

// Manually bind, wherever you need to
class PostInfo extends React.Component {
  constructor(props) {
    super(props);
    // Manually bind this method to the component instance...
    this.handleOptionsButtonClick = this.handleOptionsButtonClick.bind(this);
  }
  handleOptionsButtonClick(e) {
    // ...to ensure that "this" refers to the component instance here.
    this.setState({showOptionsModal: true});
  }
}

幸運的是,通過 ES6+ 的箭頭函數(shù)( Arrow functions )和屬性初始化( property initializers )這兩個特性使得把函數(shù)的 this 指向綁定為組件的實例變得非常的簡單:

class PostInfo extends React.Component {
  handleOptionsButtonClick = (e) => {
    this.setState({showOptionsModal: true});
  }
}

函數(shù)體內(nèi)的 this 對象,綁定定義時所在的對象,而不是使用時所在的對象。而恰好屬性初始化( property initializers )剛好在這個作用域內(nèi)。

動態(tài)屬性名 & 字符串模板

在 ES6+ 中對 對象字面量的擴(kuò)展 使得我們可以在對象字面量中使用表達(dá)式來對屬性命名。如果是在 ES5 中,我們也許只能這樣做:

var Form = React.createClass({
  onChange: function(inputName, e) {
    var stateToSet = {};
    stateToSet[inputName + "Value"] = e.target.value;
    this.setState(stateToSet);
  },
});

但是,在 ES6+ 中,我們不僅可以在對象字面量屬性的定義中使用表達(dá)式,還有使用使用 字符串模板

class Form extends React.Component {
  onChange(inputName, e) {
    this.setState({
      [`${inputName}Value`]: e.target.value,
    });
  }
}
析構(gòu) & 擴(kuò)展運算符

我們在編寫組件的過程中,經(jīng)常遇到要從父組件要把自己的很多屬性多傳給子組件的情況。有了 ES6+ 的 析構(gòu)擴(kuò)展運算符 特性,這變得非常的方便:

class AutoloadingPostsGrid extends React.Component {
  render() {
    var {
      className,
      ...others,  // contains all properties of this.props except for className
    } = this.props;
    return (
      
); } }

我們可以把 擴(kuò)展運算符 屬性和普通的屬性結(jié)合起來使用,這樣使得我們可以利用優(yōu)先級來使用屬性的默認(rèn)值和屬性的覆蓋。下面這個元素會獲得一個 override 的類( class ),及時 this.props 中有傳遞 className 屬性。

下面這種寫法,可以給元素設(shè)定默認(rèn)的 className

最后

我希望你能夠享受 ES6+ 的這些特性給你在編寫 React.js 中帶來的好處。感謝我的同事他們?yōu)檫@篇文章作出的貢獻(xiàn),還有,特別的感謝 Babel 團(tuán)隊,使得我們可以隨意的使用這些特性。

文章地址:http://blog.mcbird.cn/2015/09/11/react-on-es6-plus/

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/85975.html

相關(guān)文章

  • 即將立秋的《課多周刊》(第2期)

    摘要:即將立秋的課多周刊第期我們的微信公眾號,更多精彩內(nèi)容皆在微信公眾號,歡迎關(guān)注。若有幫助,請把課多周刊推薦給你的朋友,你的支持是我們最大的動力。課多周刊機器人運營中心是如何玩轉(zhuǎn)起來的分享課多周刊是如何運營并堅持下來的。 即將立秋的《課多周刊》(第2期) 我們的微信公眾號:fed-talk,更多精彩內(nèi)容皆在微信公眾號,歡迎關(guān)注。 若有幫助,請把 課多周刊 推薦給你的朋友,你的支持是我們最大...

    ruicbAndroid 評論0 收藏0
  • 即將立秋的《課多周刊》(第2期)

    摘要:即將立秋的課多周刊第期我們的微信公眾號,更多精彩內(nèi)容皆在微信公眾號,歡迎關(guān)注。若有幫助,請把課多周刊推薦給你的朋友,你的支持是我們最大的動力。課多周刊機器人運營中心是如何玩轉(zhuǎn)起來的分享課多周刊是如何運營并堅持下來的。 即將立秋的《課多周刊》(第2期) 我們的微信公眾號:fed-talk,更多精彩內(nèi)容皆在微信公眾號,歡迎關(guān)注。 若有幫助,請把 課多周刊 推薦給你的朋友,你的支持是我們最大...

    MRZYD 評論0 收藏0
  • 2017-08-15 前端日報

    摘要:前端日報精選變量聲明與賦值值傳遞淺拷貝與深拷貝詳解淺談自適應(yīng)學(xué)習(xí)比你想象的要簡單常見排序算法之實現(xiàn)世界萬物誕生記中文深入理解筆記與異步編程譯不可變和中的知乎專欄譯怎樣避免開發(fā)時的深坑瘋狂的技術(shù)宅在翻譯網(wǎng)格布局掘金詳解改變模糊度亮 2017-08-15 前端日報 精選 ES6 變量聲明與賦值:值傳遞、淺拷貝與深拷貝詳解淺談web自適應(yīng)學(xué)習(xí) React.js 比你想象的要簡單常見排序算法之...

    xinhaip 評論0 收藏0
  • [] 前端攻略-從路人甲到英雄無敵二:JavaScript 與不斷演化的框架

    摘要:一般來說,聲明式編程關(guān)注于發(fā)生了啥,而命令式則同時關(guān)注與咋發(fā)生的。聲明式編程可以較好地解決這個問題,剛才提到的比較麻煩的元素選擇這個動作可以交托給框架或者庫區(qū)處理,這樣就能讓開發(fā)者專注于發(fā)生了啥,這里推薦一波與。 本文翻譯自FreeCodeCamp的from-zero-to-front-end-hero-part。 繼續(xù)譯者的廢話,這篇文章是前端攻略-從路人甲到英雄無敵的下半部分,在...

    roadtogeek 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<