摘要:引入初始化使用句法定義初始化和和的聲明應(yīng)該置頂便于其他開發(fā)者閱讀。在版本,推薦使用這個包替代。組件內(nèi)的方法使用在方法中箭頭函數(shù)來替代是異步的。高階組件完整代碼在組件前聲明解構(gòu)通過函數(shù)入?yún)⒛J(rèn)值的方式設(shè)定
原文:Our Best Practices for Writing React Components .
這里意譯。有些點(diǎn)在之前的文章里提到過:#2
譯文地址:https://github.com/YutHelloWo...
如果組件帶有state或者方法,就使用Class寫法。
Class寫法如果組件帶有state或者方法,就使用Class寫法。
1. 引入CSSimport React, { Component } from "react" import { observer } from "mobx-react" import ExpandableForm from "./ExpandableForm" import "./styles/ProfileContainer.css"2. 初始化State
使用ES7句法定義state
import React, { Component } from "react" import { observer } from "mobx-react" import ExpandableForm from "./ExpandableForm" import "./styles/ProfileContainer.css" export default class ProfileContainer extends Component { state = { expanded: false }3. 初始化propTypes和defaultProps
import React, { Component } from "react" import { observer } from "mobx-react" import { string, object } from "prop-types" import ExpandableForm from "./ExpandableForm" import "./styles/ProfileContainer.css" export default class ProfileContainer extends Component { state = { expanded: false } static propTypes = { model: object.isRequired, title: string } static defaultProps = { model: { id: 0 }, title: "Your Name" }
propTypes和defaultProps的聲明應(yīng)該置頂便于其他開發(fā)者閱讀。在React v15.3.0版本,推薦使用prop-types這個包替代React.PropTypes。
重要的一點(diǎn):所有的組件都應(yīng)當(dāng)有propTypes驗(yàn)證。
import React, { Component } from "react" import { observer } from "mobx-react" import { string, object } from "prop-types" import ExpandableForm from "./ExpandableForm" import "./styles/ProfileContainer.css" export default class ProfileContainer extends Component { state = { expanded: false } static propTypes = { model: object.isRequired, title: string } static defaultProps = { model: { id: 0 }, title: "Your Name" } handleSubmit = (e) => { e.preventDefault() this.props.model.save() } handleNameChange = (e) => { this.props.model.changeName(e.target.value) } handleExpand = (e) => { e.preventDefault() this.setState({ expanded: !this.state.expanded }) }
使用在方法中箭頭函數(shù)來替代this.handleExpand.bind(this)
5. this.setState()是異步的。應(yīng)該使用函數(shù)入?yún)?/b>this.setState(prevState => ({ expanded: !prevState.expanded }))6. 一個組件或者元素含有多個props應(yīng)當(dāng)分行寫
render() { const { model, title } = this.props return (7. 避免在子組件中使用閉包) } {title}
{ model.name = e.target.value }} // ^ Not this. Use the below: onChange={this.handleChange} placeholder="Your Name"/>8.完整的class組件寫法
import React, { Component } from "react" import { observer } from "mobx-react" import { string, object } from "prop-types" // 分開本地導(dǎo)入和依賴導(dǎo)入 import ExpandableForm from "./ExpandableForm" import "./styles/ProfileContainer.css" // 使用修飾器(如果有的話) @observer export default class ProfileContainer extends Component { state = { expanded: false } // 初始化state (ES7) 或者在構(gòu)造函數(shù)(constructor)中初始化state (ES6) //使用靜態(tài)屬性(ES7)聲明propTypes越早越好 static propTypes = { model: object.isRequired, title: string } // 在propTypes后聲明defaultProps static defaultProps = { model: { id: 0 }, title: "Your Name" } // 使用箭頭函數(shù)綁定指向定義的上下文的this handleSubmit = (e) => { e.preventDefault() this.props.model.save() } handleNameChange = (e) => { this.props.model.name = e.target.value } handleExpand = (e) => { e.preventDefault() this.setState(prevState => ({ expanded: !prevState.expanded })) } render() { // 解構(gòu)props成可讀的 const { model, title } = this.props return (// 如果有2個以上props,分行寫 ) } }{title}
{ model.name = e.target.value }} // 避免創(chuàng)造新的閉包,應(yīng)該使用下面的方法。 onChange={this.handleNameChange} placeholder="Your Name"/>
---
函數(shù)式組件寫法 1. propTypesimport React from "react" import { observer } from "mobx-react" import { func, bool } from "prop-types" import "./styles/Form.css" ExpandableForm.propTypes = { onSubmit: func.isRequired, expanded: bool } // Component declaration2. Destructuring Props and defaultProps
import React from "react" import { observer } from "mobx-react" import { func, bool } from "prop-types" import "./styles/Form.css" ExpandableForm.propTypes = { onSubmit: func.isRequired, expanded: bool, onExpand: func.isRequired } function ExpandableForm(props) { const formStyle = props.expanded ? {height: "auto"} : {height: 0} return () }
結(jié)合ES6的函數(shù)入?yún)⒔鈽?gòu),可以如下書寫
import React from "react" import { observer } from "mobx-react" import { func, bool } from "prop-types" import "./styles/Form.css" ExpandableForm.propTypes = { onSubmit: func.isRequired, expanded: bool, onExpand: func.isRequired } function ExpandableForm({ onExpand, expanded = false, children, onSubmit }) { const formStyle = expanded ? {height: "auto"} : {height: 0} return () } 3. 避免箭頭函數(shù)寫法
const ExpandableForm = ({ onExpand, expanded, children }) => {
雖然語法沒問題,但是這里函數(shù)是匿名函數(shù)。
4. 高階組件import React from "react" import { observer } from "mobx-react" import { func, bool } from "prop-types" import "./styles/Form.css" ExpandableForm.propTypes = { onSubmit: func.isRequired, expanded: bool, onExpand: func.isRequired } function ExpandableForm({ onExpand, expanded = false, children, onSubmit }) { const formStyle = expanded ? {height: "auto"} : {height: 0} return () } export default observer(ExpandableForm) 5. 完整代碼
import React from "react" import { observer } from "mobx-react" import { func, bool } from "prop-types" // Separate local imports from dependencies import "./styles/Form.css" // 在組件前聲明propTypes ExpandableForm.propTypes = { onSubmit: func.isRequired, expanded: bool, onExpand: func.isRequired } // 解構(gòu)props,通過函數(shù)入?yún)⒛J(rèn)值的方式設(shè)定defaultProps function ExpandableForm({ onExpand, expanded = false, children, onSubmit }) { const formStyle = expanded ? { height: "auto" } : { height: 0 } return () } // Wrap the component instead of decorating it export default observer(ExpandableForm)
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/91432.html
摘要:原文鏈接高階組件在中是組件復(fù)用的一個強(qiáng)大工具。在本文中,高階組件將會被分為兩種基本模式,我們將其命名為和用附加的功能來包裹組件。這里我們使用泛型表示傳遞到的組件的。在這里,我們定義從返回的組件,并指定該組件將包括傳入組件的和的。 原文鏈接:https://medium.com/@jrwebdev/... 高階組件(HOCs)在React中是組件復(fù)用的一個強(qiáng)大工具。但是,經(jīng)常有開發(fā)者在...
摘要:,谷歌給的一份性能指南和最佳實(shí)踐。目前而言,前端社區(qū)有三大框架和。隨后重點(diǎn)講述了和兩大前端框架,給出了大量的文章教程和相關(guān)資源列表。我認(rèn)為,使用函數(shù)式編程方式,更加符合后端程序員的思路,而是更符合前端工程師習(xí)慣的框架。 showImg(https://segmentfault.com/img/bVbjQAM?w=1142&h=640); 這個是我訂閱 陳皓老師在極客上的專欄《左耳聽風(fēng)》...
摘要:,谷歌給的一份性能指南和最佳實(shí)踐。目前而言,前端社區(qū)有三大框架和。隨后重點(diǎn)講述了和兩大前端框架,給出了大量的文章教程和相關(guān)資源列表。我認(rèn)為,使用函數(shù)式編程方式,更加符合后端程序員的思路,而是更符合前端工程師習(xí)慣的框架。 showImg(https://segmentfault.com/img/bVbjQAM?w=1142&h=640); 這個是我訂閱 陳皓老師在極客上的專欄《左耳聽風(fēng)》...
摘要:你是一個對感興趣的開發(fā)者嗎不用擔(dān)心,這真的不會讓你成為一個背叛者或其他什么,真的。事實(shí)上,這個想法并不是或獨(dú)創(chuàng)的它只是一種很棒的軟件開發(fā)實(shí)踐方式。把代碼分離到不同的文件里并不會自動導(dǎo)致關(guān)注點(diǎn)分離。 原文鏈接 : Getting to Grips with React (as an Angular developer)原文作者 : DAVE CEDDIA譯者 : 李林璞(web前端領(lǐng)域)...
摘要:我現(xiàn)在寫的這些是為了解決和這兩個狀態(tài)管理庫之間的困惑。這甚至是危險(xiǎn)的,因?yàn)檫@部分人將無法體驗(yàn)和這些庫所要解決的問題。這肯定是要第一時(shí)間解決的問題。函數(shù)式編程是不斷上升的范式,但對于大部分開發(fā)者來說是新奇的。規(guī)模持續(xù)增長的應(yīng) 原文地址:Redux or MobX: An attempt to dissolve the Confusion 原文作者:rwieruch 我在去年大量的使用...
閱讀 3230·2023-04-26 02:27
閱讀 2146·2021-11-22 14:44
閱讀 4108·2021-10-22 09:54
閱讀 3204·2021-10-14 09:43
閱讀 759·2021-09-23 11:53
閱讀 12748·2021-09-22 15:33
閱讀 2715·2019-08-30 15:54
閱讀 2691·2019-08-30 14:04