精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

面試官:說說對React中類組件和函數組件的理解?有什么區別?

開發 前端
類組件,顧名思義,也就是通過使用ES6類的編寫形式去編寫組件,該類必須繼承React.Component。

[[410052]]

本文轉載自微信公眾號「JS每日一題」,作者灰灰。轉載本文請聯系JS每日一題公眾號。

一、類組件

類組件,顧名思義,也就是通過使用ES6類的編寫形式去編寫組件,該類必須繼承React.Component

如果想要訪問父組件傳遞過來的參數,可通過this.props的方式去訪問

在組件中必須實現render方法,在return中返回React對象,如下:

  1. class Welcome extends React.Component { 
  2.   constructor(props) { 
  3.     super(props) 
  4.   } 
  5.   render() { 
  6.     return <h1>Hello, {this.props.name}</h1> 
  7.   } 

二、函數組件

函數組件,顧名思義,就是通過函數編寫的形式去實現一個React組件,是React中定義組件最簡單的方式

  1. function Welcome(props) { 
  2.   return <h1>Hello, {props.name}</h1>; 

函數第一個參數為props用于接收父組件傳遞過來的參數

三、區別

針對兩種React組件,其區別主要分成以下幾大方向:

  • 編寫形式
  • 狀態管理
  • 生命周期
  • 調用方式
  • 獲取渲染的值

編寫形式

兩者最明顯的區別在于編寫形式的不同,同一種功能的實現可以分別對應類組件和函數組件的編寫形式

函數組件:

  1. function Welcome(props) { 
  2.   return <h1>Hello, {props.name}</h1>; 

類組件:

  1. cass Welcome extends React.Component { 
  2.   constructor(props) { 
  3.     super(props) 
  4.   } 
  5.   render() { 
  6.     return <h1>Hello, {this.props.name}</h1> 
  7.   } 

狀態管理

在hooks出來之前,函數組件就是無狀態組件,不能保管組件的狀態,不像類組件中調用setState

如果想要管理state狀態,可以使用useState,如下:

  1. const FunctionalComponent = () => { 
  2.     const [count, setCount] = React.useState(0); 
  3.  
  4.     return ( 
  5.         <div> 
  6.             <p>count: {count}</p> 
  7.             <button onClick={() => setCount(count + 1)}>Click</button> 
  8.         </div> 
  9.     ); 
  10. }; 

在使用hooks情況下,一般如果函數組件調用state,則需要創建一個類組件或者state提升到你的父組件中,然后通過props對象傳遞到子組件

生命周期

在函數組件中,并不存在生命周期,這是因為這些生命周期鉤子都來自于繼承的React.Component

所以,如果用到生命周期,就只能使用類組件

但是函數組件使用useEffect也能夠完成替代生命周期的作用,這里給出一個簡單的例子:

  1. const FunctionalComponent = () => { 
  2.     useEffect(() => { 
  3.         console.log("Hello"); 
  4.     }, []); 
  5.     return <h1>Hello, World</h1>; 
  6. }; 

上述簡單的例子對應類組件中的componentDidMount生命周期

如果在useEffect回調函數中return一個函數,則return函數會在組件卸載的時候執行,正如componentWillUnmount

  1. const FunctionalComponent = () => { 
  2.  React.useEffect(() => { 
  3.    return () => { 
  4.      console.log("Bye"); 
  5.    }; 
  6.  }, []); 
  7.  return <h1>Bye, World</h1>; 
  8. }; 

調用方式

如果是一個函數組件,調用則是執行函數即可:

  1. // 你的代碼  
  2. function SayHi() {  
  3.     return <p>Hello, React</p>  
  4. }  
  5. // React內部  
  6. const result = SayHi(props) // » <p>Hello, React</p> 

如果是一個類組件,則需要將組件進行實例化,然后調用實例對象的render方法:

  1. // 你的代碼  
  2. class SayHi extends React.Component {  
  3.     render() {  
  4.         return <p>Hello, React</p>  
  5.     }  
  6. }  
  7. // React內部  
  8. const instance = new SayHi(props) // » SayHi {}  
  9. const result = instance.render() // » <p>Hello, React</p> 

獲取渲染的值

首先給出一個示例

函數組件對應如下:

  1. function ProfilePage(props) { 
  2.   const showMessage = () => { 
  3.     alert('Followed ' + props.user); 
  4.   } 
  5.  
  6.   const handleClick = () => { 
  7.     setTimeout(showMessage, 3000); 
  8.   } 
  9.  
  10.   return ( 
  11.     <button onClick={handleClick}>Follow</button> 
  12.   ) 

類組件對應如下:

  1. class ProfilePage extends React.Component { 
  2.   showMessage() { 
  3.     alert('Followed ' + this.props.user); 
  4.   } 
  5.  
  6.   handleClick() { 
  7.     setTimeout(this.showMessage.bind(this), 3000); 
  8.   } 
  9.  
  10.   render() { 
  11.     return <button onClick={this.handleClick.bind(this)}>Follow</button> 
  12.   } 

兩者看起來實現功能是一致的,但是在類組件中,輸出this.props.user,Props在 React中是不可變的所以它永遠不會改變,但是 this 總是可變的,以便您可以在 render 和生命周期函數中讀取新版本

因此,如果我們的組件在請求運行時更新。this.props 將會改變。showMessage方法從“最新”的 props 中讀取 user

而函數組件,本身就不存在this,props并不發生改變,因此同樣是點擊,alert的內容仍舊是之前的內容

小結

兩種組件都有各自的優缺點

函數組件語法更短、更簡單,這使得它更容易開發、理解和測試

 

而類組件也會因大量使用 this而讓人感到困惑

 

責任編輯:武曉燕 來源: JS每日一題
相關推薦

2021-06-30 07:19:36

React事件機制

2021-07-12 08:35:24

組件應用場景

2021-07-07 08:36:45

React應用場景

2021-07-13 07:52:03

ReactHooks組件

2021-07-29 07:55:20

React Fiber架構引擎

2021-09-13 09:23:52

TypeScript命名空間

2021-07-09 08:33:35

React組件受控

2021-08-13 07:56:13

Git pullGit fetch倉庫里

2021-06-03 08:14:01

NodeProcessJavaScript

2021-05-31 10:35:34

TCPWebSocket協議

2023-12-13 13:31:00

useEffect對象瀏覽器

2021-06-04 07:55:30

Node Fs 操作

2024-05-30 08:04:20

Netty核心組件架構

2021-12-23 07:11:31

開發

2021-07-02 07:06:20

React組件方式

2021-06-07 09:41:48

NodeBuffer 網絡協議

2021-06-08 08:33:23

NodeStream數據

2023-02-17 08:10:24

2021-06-10 07:51:07

Node.js循環機制

2021-10-29 09:40:21

設計模式軟件
點贊
收藏

51CTO技術棧公眾號

国产免费黄色一级片| 九九九久久国产免费| 日韩欧美xxxx| 日本中文字幕在线视频| 国产精品亚洲综合一区在线观看| 久久久黄色av| 亚洲色图14p| 欧美91在线|欧美| 亚洲国产中文字幕在线视频综合| 欧美日韩国产高清视频| 国产精品无码久久av| 亚洲国产网站| 中国日韩欧美久久久久久久久| 国产大片一区二区三区| 色一区二区三区| 亚洲视频1区2区| 快播日韩欧美| 日韩在线视频线视频免费网站| 日韩三级电影| 农村少妇久久久久久久| 日本亚洲三级在线| 久久久久久久亚洲精品| 特黄一区二区三区| 日韩一级电影| 欧美精品一区二区三区蜜臀| 在线免费视频一区| 秋霞伦理一区| 夜色激情一区二区| 亚洲一区二区三区免费看| 无码国产精品一区二区色情男同| 国产一区二区三区黄视频| 欧美二区乱c少妇| 欧美一区二区三区人| 久久久久久久香蕉| 国产专区在线播放| 成人黄色777网| 成人精品视频在线| 精品乱码一区内射人妻无码| 亚洲一卡久久| 97精品视频在线| 欧美日韩大片在线观看| 国产高清一区| 中文字幕亚洲无线码a| 免费一级做a爰片久久毛片潮| 波多野结衣欧美| 欧美一区二区视频网站| 激情五月婷婷基地| 国产成人精品一区二区三区免费| 色琪琪一区二区三区亚洲区| 91精品91久久久中77777老牛| 爱草tv视频在线观看992| 亚洲免费在线视频一区 二区| 亚欧精品在线| 91官网在线| 国产精品久久久久影院老司| 亚洲毛片aa| 日韩av中文| 亚洲日本青草视频在线怡红院 | 久久久久久久久久久av| 欧美日韩在线观看成人| 午夜欧美视频| 97精品国产97久久久久久春色| 久久网一区二区| 激情五月***国产精品| 国内伊人久久久久久网站视频 | 裸模一区二区三区免费| 五月婷婷六月色| 久久综合久色欧美综合狠狠| 成人福利视频在线| 色综合久久久888| 久久中文字幕在线观看| 在线看片成人| 97高清免费视频| 人妻丰满熟妇av无码区| 肉肉av福利一精品导航| 国产一区欧美二区三区| av加勒比在线| fc2成人免费人成在线观看播放 | 欧美wwwww| 色综合久久悠悠| 日本特黄特色aaa大片免费| 一区二区三区精品视频在线观看| 欧美自拍视频在线| 在线免费观看一区二区| 国产一区二区调教| 国产自产在线视频一区| 国产小视频免费在线网址| 国产精品网曝门| 国产91视频一区| 性感女国产在线| 日韩精品久久久久久久软件91| 五月婷婷欧美视频| 99福利在线观看| 高清一区二区三区av| 亚洲大胆人体av| 久久午夜精品视频| 黄色国产精品| 国产精品久久久久高潮| www黄色在线观看| 国产三级欧美三级日产三级99| 亚洲视频小说| 国产在线美女| 在线播放91灌醉迷j高跟美女| 人妻换人妻a片爽麻豆| 怕怕欧美视频免费大全| 欧美成人四级hd版| 国产精品久久久久久久久夜色| 国产一区在线观看视频| 久久综合给合久久狠狠色| 欧美精品videos另类| 亚洲成人自拍网| www.这里只有精品| 不许穿内裤随时挨c调教h苏绵| 日韩在线免费看| 日韩理论片在线| 欧美污视频网站| jizz18欧美18| 久久av在线看| 最新黄色网址在线观看| 97精品国产露脸对白| 中文字幕超清在线免费观看| 精品3atv在线视频| 亚洲国产精品久久久久| 日本中文字幕免费在线观看| 日韩电影免费在线观看网站| 精品一区二区三区免费毛片| 尤物视频在线看| 欧美日韩色一区| 欧美成人国产精品一区二区| 日韩视频精品在线观看| 91免费在线观看网站| 日本三级视频在线播放| 色综合久久中文字幕| 丝袜熟女一区二区三区 | 亚洲人成网亚洲欧洲无码| 日韩一级黄色av| 中文字幕 人妻熟女| 91亚洲精品一区二区乱码| 欧美一级爱爱视频| 国产一区二区三区免费在线| 日韩视频第一页| 一级黄色短视频| 国产精品丝袜黑色高跟| 天天操天天摸天天爽| 久久爱www成人| 国产v综合ⅴ日韩v欧美大片 | 日韩视频免费播放| silk一区二区三区精品视频 | 亚洲色图综合网| 免费观看成人毛片| 99久久精品国产精品久久| 国产乱淫av片杨贵妃| 亚洲乱码一区| 亚洲天堂av一区| 91国内在线视频| 亚洲成熟女性毛茸茸| 一区二区三区在线观看视频| 99热这里只有精品2| 中文精品久久| 国产91aaa| 久草免费在线视频| 亚洲理论在线a中文字幕| 国产亚洲欧美在线精品| 国产亚洲人成网站| 99视频在线视频| 久久人体视频| 91香蕉视频在线下载| 黄色污污视频在线观看| 日韩av在线一区二区| 亚洲天堂一区在线| 欧美激情一二三区| 中文字幕第一页在线视频| 欧美福利电影在线观看| 国产精品一国产精品最新章节| 国产粉嫩在线观看| 亚洲性猛交xxxxwww| 一级做a爰片久久毛片16| 性xx色xx综合久久久xx| 亚洲国产精品女人久久久| 日本午夜视频在线观看| 国产欧美一区在线| 97超碰人人看| 亚洲女同在线| 久久久国产精华液999999| 在线播放一区二区精品视频| 欧美最猛性xxxxx免费| 中文日本在线观看| 亚洲精品一区二区在线观看| 精品久久久久久久久久久久久久久久 | 亚洲国产裸拍裸体视频在线观看乱了| 国产又粗又长又爽| 免费在线欧美视频| 男人添女人下部视频免费| 亚洲人挤奶视频| 国产一区二区色| 91在线三级| 最近中文字幕2019免费| 风流老熟女一区二区三区| 色老汉一区二区三区| 国产大片免费看| 久久久午夜电影| 国产成人精品综合久久久| 国产高清自拍视频| 奇米精品一区二区三区在线观看| 国产911在线观看| 奇米亚洲欧美| 岛国视频一区| 欧美黄色a视频| 欧美一级淫片videoshd| 中中文字幕av在线| 最好看的2019的中文字幕视频| 国产小视频一区| 欧美情侣在线播放| 国产字幕在线观看| 亚洲二区在线观看| 久久久精品视频免费观看| 国产亚洲欧美日韩在线一区| 日本一级大毛片a一| 精品在线播放免费| 黄色av免费在线播放| 亚洲激情精品| 欧美 亚洲 视频| 日韩中文欧美| 热re99久久精品国产99热| 超碰成人97| 91精品国产一区二区三区动漫| 六九午夜精品视频| 国产ts一区二区| 筱崎爱全乳无删减在线观看| 97激碰免费视频| 成人女同在线观看| 欧美人在线观看| 超碰在线观看免费版| 中文字幕日韩精品在线| 精品999视频| 91在线小视频| 国产精品初高中精品久久| 日韩专区视频| 国产免费亚洲高清| h1515四虎成人| 国产精品国语对白| 成人看片网页| 国产精品色婷婷视频| 69堂免费精品视频在线播放| 国产精品成人aaaaa网站| 久久久久久久| 日韩av片免费在线观看| 国产不卡网站| 国产精品a久久久久久| 都市激情亚洲一区| 日韩av免费一区| 日韩经典一区| 91精品国产综合久久久久久蜜臀| 欧美天堂一区二区| 成人亚洲欧美一区二区三区| 99久久999| 97人人干人人| 久久影院资源站| 欧美欧美一区二区| 欧美日韩一区二区综合 | 青青草在线免费观看| 亚洲男人天堂2023| 美国黑人一级大黄| 九一成人免费视频| 欧美日韩在线一二三| 欧美一二区在线观看| 一本久道久久综合狠狠爱亚洲精品| 国产精品99视频| 毛片av在线播放| 亚洲欧美日韩视频二区| 91色国产在线| 国产伦精品一区二区三区免费迷| 国产高潮失禁喷水爽到抽搐| 95精品视频在线| 天天操天天干天天操天天干| 国产精品久久久久7777按摩| 免费中文字幕在线观看| 日韩欧美在线观看| 国产美女免费看| 亚洲国产成人在线视频| 北岛玲一区二区三区| 久久高清视频免费| 国产高清中文字幕在线| 国产suv精品一区二区| 国产精品一区免费在线| 精品国产一区二区三区麻豆小说 | 国产福利精品一区二区三区| 成人午夜激情视频| 91资源在线播放| 一区二区三区精品| 日本人69视频| 爱草tv视频在线观看992| 国a精品视频大全| 欧美日韩五区| 波多野结衣精品久久| 国产亚洲第一伦理第一区| 91xxx视频| 久久最新视频| 深夜视频在线观看| 国产午夜亚洲精品羞羞网站| 青春草免费视频| 在线观看一区不卡| 蜜桃视频在线观看www| 日韩小视频网址| 亚洲人成在线网站| 99爱精品视频| 久久香蕉国产| 国产aaa一级片| 国产成人一区二区精品非洲| 性欧美一区二区| 性做久久久久久免费观看| 国产精品爽爽久久久久久| 亚洲性生活视频在线观看| 波多野结衣乳巨码无在线观看| 国产欧美 在线欧美| 国产成人一区| 波多野结衣家庭教师在线播放| 国产高清无密码一区二区三区| 女人黄色一级片| 色综合一区二区| 天天舔天天干天天操| 久久久99精品久久| 亚洲欧美国产精品桃花| 亚洲激情欧美| 最好看的中文字幕| 中文一区在线播放| av毛片在线免费观看| 亚洲精品成人久久电影| 欧美78videosex性欧美| 亚洲www在线| 国产国产精品| 国产乱码一区二区三区四区| 中文字幕乱码一区二区免费| 黄色片网站在线免费观看| 亚洲精品一区二区三区精华液| 成人在线播放免费观看| 成人激情免费在线| 色综合蜜月久久综合网| 亚洲最大综合网| 中文字幕欧美三区| 中文字幕乱码无码人妻系列蜜桃| 亚洲人成电影网站| 激情开心成人网| 欧美久久电影| 久久久国产精品一区二区中文| 91视频啊啊啊| 色综合天天综合狠狠| 日本护士...精品国| 欧美在线国产精品| 日韩母乳在线| 免费在线观看的毛片| 国产欧美中文在线| 在线免费观看一区二区| 久久五月天综合| 91香蕉视频在线播放| 亚洲第一狼人社区| 午夜在线视频免费| 欧美在线欧美在线| 精品99久久| 福利片一区二区三区| 亚洲欧美激情小说另类| 成人1区2区3区| 久久久久久久影院| 亚洲精品动态| 手机看片福利日韩| 亚洲视频一区在线| 亚洲第一免费视频| 91国偷自产一区二区三区的观看方式| 亚洲日本三级| www.国产视频.com| 亚洲夂夂婷婷色拍ww47| 视频三区在线观看| 国产精品欧美激情在线播放| 香蕉综合视频| 屁屁影院国产第一页| 在线视频国内自拍亚洲视频| 日本中文字幕在线播放| 国产伦精品一区二区三区免| 老鸭窝毛片一区二区三区| 亚洲综合图片一区| 精品国产第一区二区三区观看体验| 美女高潮在线观看| 亚洲一二三区精品| 成人美女视频在线观看18| 亚洲精品成人在线视频| 久久激情视频免费观看| 精品久久对白| 国产免费又粗又猛又爽| 夜夜精品视频一区二区 | 国产精品外国| 蜜桃av.com| 亚洲精品动漫100p| 欧美成人毛片| 国产精品久久中文字幕| 国产精品久久久久三级| 天堂在线视频观看| 成人有码视频在线播放| 亚洲欧美高清| 九九在线观看视频| 在线视频欧美日韩|