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

資訊專欄INFORMATION COLUMN

當(dāng)我開始使用React 時(shí),我希望我知道這些知識(shí)

suosuopuo / 1470人閱讀

摘要:自年月日首次發(fā)布以來,已經(jīng)占領(lǐng)了互聯(lián)網(wǎng)。我和許多其他開發(fā)人員將他們的成功歸功于這個(gè)了不起的框架,這已經(jīng)不是什么秘密了。不要驚慌,查看將它注銷掉從版本開始,默認(rèn)為。彈出項(xiàng)目就像打開正在運(yùn)行的汽車的引擎蓋,同時(shí)動(dòng)態(tài)地更換引擎,使其運(yùn)行速度提高。

自2013年5月29日首次發(fā)布以來,React.js已經(jīng)占領(lǐng)了互聯(lián)網(wǎng)。我和許多其他開發(fā)人員將他們的成功歸功于這個(gè)了不起的框架,這已經(jīng)不是什么秘密了。

想閱讀更多優(yōu)質(zhì)文章請(qǐng)猛戳GitHub博客,一年百來篇優(yōu)質(zhì)文章等著你!

使用箭頭函數(shù)時(shí)不需要 .bind(this)

通常,如果有一個(gè)受控組件時(shí),會(huì)有如下的結(jié)構(gòu):

class Foo extends React.Component{
  constructor( props ){
    super( props );
    this.handleClick = this.handleClick.bind(this);
  }
  handleClick(event){
    // your event handling logic
  }
  render(){
    return (
      
    );
  }
}

可以給每個(gè)方法加上.bind(this)來解決 this 指向的問題,因?yàn)榇蠖鄶?shù)教程都告訴你這樣做。如果你有幾個(gè)受控組件,那么constructor(){}中就會(huì)有一大堆代碼。

相反,你可以這樣做:
class Foo extends React.Component{
  handleClick = (event) => {
    // your event handling logic
  }
  render(){
    return (
      
    );
  }
}

ES6 的箭頭函數(shù)使用詞法作用域,它允許方法訪問 this 觸發(fā)的地方。

當(dāng) service worker 與你的代碼沖突時(shí)

Service workers 非常適合漸進(jìn)式Web應(yīng)用程序,它允許離線訪問并優(yōu)化互聯(lián)網(wǎng)連接較差的用戶。

但是當(dāng)你不知道服務(wù)工作者正在緩存靜態(tài)文件時(shí),你會(huì)反復(fù)上傳熱修復(fù)程序, 卻發(fā)現(xiàn)你的網(wǎng)站一直沒有更新。

不要驚慌,查看 src/index.js

// 將它注銷掉
serviceWorker.unregister();


從16.8版本開始,默認(rèn)為 serverWorker.unregister()。

但如果你想改變它的狀態(tài),你就知道在哪里改了。

99% 的情況下你不需要運(yùn)行 eject 命令

Create React APP 提供了一個(gè)選項(xiàng) yarn eject,可以彈出項(xiàng)目來定制構(gòu)建過程。

我記得曾嘗試自定義構(gòu)建過程,使SVG圖像自動(dòng)內(nèi)聯(lián)到代碼中。 我花了幾個(gè)小時(shí)試圖了解構(gòu)建過程。最后,我們得到了一個(gè)導(dǎo)入文件,該文件注入 SVG 標(biāo)記,我們將網(wǎng)站的加載速度提高了0.0001毫秒。

彈出 React 項(xiàng)目就像打開正在運(yùn)行的汽車的引擎蓋,同時(shí)動(dòng)態(tài)地更換引擎,使其運(yùn)行速度提高1%。

當(dāng)然,如果你已經(jīng)是一個(gè) Webpack 高手,那么定制構(gòu)建過程來定制項(xiàng)目的需求是值得的。

當(dāng)你想按時(shí)完成任務(wù)時(shí),把精力集中在它能推動(dòng)你前進(jìn)的地方。

ESlint Auto 保存自動(dòng)格式化可節(jié)省大量時(shí)間

你可能已經(jīng)從某些沒有格式化的地方復(fù)制了一些代碼。因?yàn)槟銦o法忍受它看起來有多丑,你花時(shí)間手動(dòng)添加空格。

使用 ESLint 和 Visual Studio 代碼插件,它可以在保存時(shí)為你格式化它。

要怎么設(shè)置

1.在你的 package.json 中,添加一些dev依賴項(xiàng)并執(zhí)行 npm iyarn

"devDependencies": {
 "eslint-config-airbnb": "^17.1.0",
 "eslint-config-prettier": "^3.1.0",
 "eslint-plugin-import": "^2.14.0",
 "eslint-plugin-jsx-a11y": "^6.1.1",
 "eslint-plugin-prettier": "^3.0.0",
 "eslint-plugin-react": "^7.11.0"
}

2.安裝 ESLint 插件

3.啟動(dòng) Auto Fix On Save

你不需要Redux、styled-components 等等

每種工具都有其目的。也就是說,了解不同的工具是件好事。

如果你手上只有一把錘子,那么所有的東西看起來都像釘子

你需要考慮使用的一些庫的設(shè)置時(shí)間,并將其與之進(jìn)行比較。

我要解決的問題是什么

這個(gè)項(xiàng)目能長久地受益于這個(gè)庫嗎

React是否已經(jīng)提供了一些現(xiàn)成的東西

現(xiàn)在可以使用 React 的 Context 和 Hook,你還需要Redux嗎?

當(dāng)你的用戶處于糟糕的互聯(lián)網(wǎng)連接環(huán)境時(shí),我強(qiáng)烈建議使用 Redux Offline。

使用事件處理程序

如果您不想反復(fù)輸入相同的內(nèi)容,可以選擇重用事件處理程序:

class App extends Component {
 constructor(props) {
  super(props);
  this.state = {
   foo: "",
   bar: "",
  };
 }
 // Reusable for all inputs
 onChange = e => {
  const {
   target: { value, name },
  } = e;
  
  // name will be the state name
  this.setState({
   [name]: value
  });
 };
 
 render() {
  return (
   
); } }
setState是異步的

天真的我會(huì)寫一些像如下的代碼:

 constructor(props) {
  super(props);
  this.state = {
   isFiltered: false
  };
 }
 toggleFilter = () => {
  this.setState({
   isFiltered: !this.state.isFiltered
  });
  this.filterData();
 };
 
 filterData = () => {
  //  this.state.isFiltered 應(yīng)該是 true,但事實(shí)并非如此,因?yàn)?setState 是異步的
  // isFiltered還沒有改變
  if (this.state.isFiltered) {
   // Do some filtering
  }
 };

正確做法一:將狀態(tài)傳遞下去
toggleFilter = () => {
 const currentFilterState = !this.state.isFiltered;
 this.setState({
  isFiltered: currentFilterState
 });
 this.filterData(currentFilterState);
};
filterData = (currentFilterState) => {
 if (currentFilterState) {
  // Do some filtering
 }
};
正確做法二:使用 setState 回調(diào)函數(shù)
toggleFilter = () => {
 this.setState((prevState) => ({
  isFiltered: !prevState.isFiltered
 }), () => {
  this.filterData();
 });
};
filterData = () => {
  if (this.state.isFiltered) {
   // Do some filtering
  }
};

總結(jié)

這些技巧為我節(jié)省了很多時(shí)間,我相信還有更多。請(qǐng)?jiān)谠u(píng)論區(qū)與我們分享。

你的點(diǎn)贊是我持續(xù)分享好東西的動(dòng)力,歡迎點(diǎn)贊!

交流

干貨系列文章匯總?cè)缦?,覺得不錯(cuò)點(diǎn)個(gè)Star,歡迎 加群 互相學(xué)習(xí)。

https://github.com/qq44924588...

我是小智,公眾號(hào)「大遷世界」作者,對(duì)前端技術(shù)保持學(xué)習(xí)愛好者。我會(huì)經(jīng)常分享自己所學(xué)所看的干貨,在進(jìn)階的路上,共勉!

關(guān)注公眾號(hào),后臺(tái)回復(fù)福利,即可看到福利,你懂的。

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

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

相關(guān)文章

  • 通過閱讀源碼來提高js知識(shí)

    摘要:在這篇文章中,分享了他如何克服恐懼并開始使用源代碼來提高他的知識(shí)和技能。不久之后,你正在閱讀的源代碼將引導(dǎo)您進(jìn)入規(guī)范。 通過閱讀源碼來提高js知識(shí) 原文傳送門:《Improve Your JavaScript Knowledge By Reading Source Code》 showImg(https://segmentfault.com/img/remote/14600000197...

    浠ラ箍 評(píng)論0 收藏0
  • 7個(gè) HTML 面試題及回答策略

    摘要:接下來,我會(huì)檢查每個(gè)頁面以確保它使用有用的標(biāo)簽,包括標(biāo)題標(biāo)簽。這個(gè)問題讓面試官有機(jī)會(huì)了解潛在員工對(duì)工作難以勝任的部分。面試官可能需要考慮這種弱點(diǎn)對(duì)團(tuán)隊(duì)的影響。面試官可能會(huì)發(fā)現(xiàn)自己公司的計(jì)劃與未來員工的職業(yè)目標(biāo)是否保持一致。 翻譯:瘋狂的技術(shù)宅原文:https://www.indeed.com/hire/i... 本文首發(fā)微信公眾號(hào):jingchengyideng歡迎關(guān)注,每天都給你...

    Luosunce 評(píng)論0 收藏0
  • 是如何在自學(xué)編程9個(gè)月后找到工作的

    摘要:昨天在我在國外網(wǎng)站上看到一篇文章,作者分享了他自學(xué)編程個(gè)月后找到工作的經(jīng)歷。而本文中,我主要針對(duì)想要通過學(xué)習(xí)編程找工作的角度來談。我在年月犯了一個(gè)錯(cuò)誤我認(rèn)為首要任務(wù)是找到一份前端開發(fā)的工作。 昨天在我在國外網(wǎng)站 reddit 上看到一篇文章,作者分享了他 自學(xué)編程 9 個(gè)月后找到工作 的經(jīng)歷。文章不到一天就得到3千多贊,2百條回復(fù)。我看了下內(nèi)容,非常中肯,其中有不少建議也是我在編程教室...

    gaosboy 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<