嫩草影院久久99_老司机午夜网站国内精品久久久久久久久_久久夜色精品国产_国产一级做a爰片久久毛片

react框架

2020-3-18    seo達人

環境準備

創建項目



npx create-react-app my-react



進入項目并啟動



cd my-react && npm start

1

src/index.js

先把src里面的東西全部刪掉,重寫了index.js



import React from 'react';

import ReactDOM from 'react-dom';



class App extends React.Component{

render(){

return (

<div>Hellow, World</div>

)

}

}



ReactDOM.render(<App/>, document.getElementById('root'));



JSX

一個React組件中,render方法中return出去的內容就是這個組件將要渲染的內容,然后Babel 會把 JSX 轉譯成一個名為 React.createElement() 函數調用。



React.createElement(

  'div',

  {},

  'Hello, World'

)



React.createElement() 接收三個參數:

第一個參數是必填,傳入的是似HTML標簽名稱: ul, li, div;

第二個參數是選填,表示的是屬性: className;

第三個參數是選填, 子節點: 要顯示的文本內容;

React.createElement() 會預先執行一些檢查,以幫助你編寫無錯代碼,但實際上它創建了一個這樣的對象:



// 注意:這是簡化過的結構

const element = {

  type: 'div',

  props: {

    className: '',

    children: 'Hello, world!'

  }

};



元素渲染

與瀏覽器的 DOM 元素不同,React 元素是創建開銷極小的普通對象。React DOM 會負責更新 DOM 來與 React 元素保持一致。

想要將一個 React 元素渲染到根 DOM 節點中,只需把它們一起傳入 ReactDOM.render():



const element = <h1>Hello, world</h1>;

ReactDOM.render(element, document.getElementById('root'));



render方法接收兩個參數,第一個參數為我們的 React 根級組件,第二個參數接收一個 DOM 節點,代表我們將把和 React 應用掛載到這個 DOM 節點下,進而渲染到瀏覽器中。



組件 & props

組件,從概念上類似于 JavaScript 函數。它接受任意的入參(即 “props”),并返回用于描述頁面展示內容的 React 元素。

函數組件:



function Welcome(props){

renter (

<h1> Hello, {props.name} </h1>

)

}

<Welcome name="World"/>



該函數是一個有效的 React 組件,因為它接收唯一帶有數據的 “props”(代表屬性)對象與并返回一個 React 元素。這類組件被稱為“函數組件”,因為它本質上就是 JavaScript 函數。

class組件:



class Welcome extends React.Component {

render(){

renter (

<h1> Hello, {thhis.props.name} </h1>

)

}

}

<Welcome name="World"/>



組件名稱必須以大寫字母開頭。

組件無論是使用函數聲明還是通過 class 聲明,都決不能修改自身的 props。



State & 生命周期

State 與 props 類似,但是 state 是私有的,并且完全受控于當前組件。



class Clock extends React.Component {

constructor(props){

super(props)

this.state = {

date : new Date()

}

}

componentDidMount() {

//這里是Clock組件第一次被渲染到DOM時會調用,也就是掛載

}



componentWillUnmount() {

//當DOM組件Clock被刪除時,會調用,也就是卸載

}

render(){

return (

<div>

<h1>Hello, World</h1>

<h2>It's {this.state.date.toLocaleTimeString()}</h2>

</div>

)

}

}



修改state中數據:



class Clock extends React.Component {

constructor(props){

super(props)

this.state = {

date: new Date()

}

}

componentDidMount() {

//這里是Clock組件第一次被渲染到DOM時會調用,也就是掛載

this.timer = setInterval(()=>{

this.tick()

},1000)

}



tick(){

this.setState({

date: new Date()

})

}



componentWillUnmount() {

//當DOM組件Clock被刪除時,會調用,也就是卸載

clearInterval(this.timer)

}

render(){

return (

<div>

<h1>Hello, World</h1>

<h2>It's {this.state.date.toLocaleTimeString()}</h2>

</div>

)

}

}



不要直接修改 State,構造函數是唯一可以給 this.state 賦值的地方



this.setState({name: 'World'})

1

State 的更新可能是異步的,要解決這個問題,可以讓setState接受一個函數而不是一個對象,這個函數用上一個 state 作為第一個參數,將此次更新被應用時的 props 做為第二個參數:



this.setState((state, props) => ({

  counter: state.counter + props.increment

}));



事件處理

React 事件的命名采用小駝峰式(camelCase),而不是純小寫。

使用 JSX 語法時你需要傳入一個函數作為事件處理函數,而不是一個字符串。

在 React 中一個不同點是你不能通過返回 false 的方式阻止默認行為。你必須顯式的使用 preventDefault 。例如,傳統的 HTML 中阻止鏈接默認打開一個新頁面,你可以這樣寫:



<a href="#" onclick="console.log('The link was clicked.'); return false">

  Click me

</a>



在 React 中,可能是這樣的:



function ActionLink() {

  function handleClick(e) {

    e.preventDefault();

    console.log('The link was clicked.');

  }



  return (

    <a href="#" onClick={handleClick}>

      Click me

    </a>

  );

}



class函數中綁定this



class LoggingButton extends React.Component {

  handleClick() {

    console.log('this is:', this);

  }



  render() {

    // 此語法確保 handleClick 內的 this 已被綁定。

    return (

      <button onClick={() => this.handleClick()}>

        Click me

      </button>

    );

  }

}



在循環中,通常我們會為事件處理函數傳遞額外的參數



<button onClick={(e) => this.deleteRow(id, e)}>Delete Row</button>

<button onClick={this.deleteRow.bind(this, id)}>Delete Row</button>

1

2

列表和key



function ListItem(props) {

  return <li>{props.value}</li>;

}



function NumberList(props) {

  const numbers = props.numbers;

  const listItems = numbers.map((number) =>

    <ListItem key={number.toString()}  value={number} />

  );

  return (

    <ul>

      {listItems}

    </ul>

  );

}



const numbers = [1, 2, 3, 4, 5];

ReactDOM.render(

  <NumberList numbers={numbers} />,

  document.getElementById('root')

);



語法

在 JSX 中所有的屬性都要更換成駝峰式命名,比如 onclick 要改成 onClick,唯一比較特殊的就是 class,因為在 JS 中 class 是保留字,我們要把 class 改成 className 。


日歷

鏈接

個人資料

藍藍設計的小編 http://m.sdgs6788.com

存檔

嫩草影院久久99_老司机午夜网站国内精品久久久久久久久_久久夜色精品国产_国产一级做a爰片久久毛片
<em id="09ttv"></em>
    <sup id="09ttv"><pre id="09ttv"></pre></sup>
    <dd id="09ttv"></dd>

        • 国产精品夜夜夜一区二区三区尤| 亚洲一区二区三区免费视频| 亚洲精品一区在线观看香蕉| 亚洲高清不卡av| 樱桃国产成人精品视频| 国产曰批免费观看久久久| 国产在线一区二区三区四区 | 国产亚洲欧洲| 国产主播一区| 亚洲国产日韩在线一区模特| 一区二区三区鲁丝不卡| 久久超碰97中文字幕| 国产视频精品免费播放| 国内精品视频在线播放| 亚洲精品一二区| 午夜日韩在线观看| 久久影视精品| 亚洲另类一区二区| 亚洲欧美制服另类日韩| 欧美成人国产一区二区| 国产精品视屏| 亚洲精品一区二区在线观看| 欧美一区二区三区四区在线 | 狠色狠色综合久久| 最新国产精品拍自在线播放| 亚洲一区在线观看视频| 模特精品裸拍一区| 亚洲五月六月| 欧美激情bt| 国内精品久久久久国产盗摄免费观看完整版| 国内精品免费在线观看| 亚洲一区二区高清| 欧美高清视频一区二区三区在线观看| 夜夜精品视频一区二区| 免费欧美在线| 狠狠干成人综合网| 欧美一区二区三区四区在线 | 亚洲少妇中出一区| 久久综合色88| 欧美在线观看网站| 国产精品欧美久久| av不卡在线观看| 欧美激情一区二区三区蜜桃视频| 先锋亚洲精品| 国产精品视频xxx| 亚洲午夜精品在线| 亚洲日本理论电影| 欧美在线一级视频| 国产精品区一区| 亚洲性图久久| 亚洲欧洲久久| 欧美成人嫩草网站| 亚洲国产日韩欧美在线图片| 免费不卡亚洲欧美| 久久精品视频va| 国内精品免费午夜毛片| 久久久久88色偷偷免费| 亚洲欧美日韩一区在线| 国产精品五区| 欧美在线精品一区| 欧美一区三区三区高中清蜜桃| 国产精品电影网站| 亚洲免费在线播放| 亚洲视频网在线直播| 国产精品久久久亚洲一区| 欧美亚洲日本国产| 欧美一区二区在线| 在线成人中文字幕| 亚洲高清自拍| 欧美揉bbbbb揉bbbbb| 亚洲永久免费精品| 香港久久久电影| 一区二区视频在线观看| 免费成年人欧美视频| 牛夜精品久久久久久久99黑人| 亚洲精品一区二区三区av| 亚洲精品综合在线| 国产精品综合色区在线观看| 久久免费视频在线| 久久先锋资源| 宅男噜噜噜66一区二区66| 亚洲欧美www| 狠狠色丁香婷婷综合| 欧美激情亚洲一区| 国产精品成人免费| 久久久久久久久综合| 欧美激情视频一区二区三区免费 | 久久久在线视频| 欧美va天堂va视频va在线| 亚洲校园激情| 久久精品男女| 一区二区三区国产| 久久久91精品国产一区二区三区 | 欧美日韩直播| 久久久久国色av免费看影院| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲毛片网站| 亚洲欧美中文在线视频| 91久久精品视频| 亚洲午夜国产成人av电影男同| 国产日韩欧美在线| 亚洲国产精品va在看黑人| 国产精品婷婷午夜在线观看| 亚洲福利免费| 国产一区二区三区免费不卡| 亚洲精品网址在线观看| 国产一区二区精品| 亚洲精品永久免费| 在线成人激情黄色| 亚洲午夜一区| 夜夜嗨av一区二区三区免费区| 午夜精品剧场| 亚洲视频观看| 欧美1区视频| 久久综合狠狠综合久久激情| 欧美性色综合| 999亚洲国产精| 99精品视频免费| 理论片一区二区在线| 久久久91精品国产一区二区精品| 欧美三级韩国三级日本三斤| 欧美国产视频一区二区| 激情欧美一区二区| 亚洲性av在线| 亚洲一本大道在线| 欧美久久电影| 亚洲国产欧美在线| 久久久亚洲国产美女国产盗摄| 亚洲欧美日韩久久精品| 欧美日韩高清在线播放| 亚洲国产精彩中文乱码av在线播放| 国产精品永久入口久久久| 日韩一二在线观看| 亚洲小视频在线观看| 欧美日韩亚洲一区三区| 一本一本大道香蕉久在线精品| 一区二区国产日产| 欧美日韩成人综合在线一区二区| 欧美国产在线观看| 亚洲国产精品激情在线观看| 久久视频这里只有精品| 欧美成人免费观看| 亚洲欧洲一级| 欧美精品久久久久久久免费观看| 亚洲国产精品高清久久久| 亚洲免费观看| 欧美日韩情趣电影| 99这里只有精品| 亚洲欧美电影在线观看| 国产精品免费看久久久香蕉| 亚洲专区一二三| 久久久久国色av免费看影院| 在线观看不卡| 欧美日韩精品免费观看| 亚洲一区二区三区四区中文| 久久视频在线看| 亚洲国产成人在线播放| 欧美精品免费在线观看| 制服丝袜亚洲播放| 久久精品国产免费| 亚洲国产精品毛片| 欧美三日本三级少妇三2023| 亚洲欧美日韩精品| 亚洲第一综合天堂另类专| 正在播放亚洲| 国产夜色精品一区二区av| 欧美 日韩 国产一区二区在线视频 | 久久国产精品高清| 亚洲成人直播| 亚洲专区欧美专区| 国产一区三区三区| 欧美另类在线播放| 欧美一区二区私人影院日本| 亚洲韩国精品一区| 久久精品国产亚洲一区二区| 亚洲国产日韩美| 国产嫩草影院久久久久| 欧美成人a∨高清免费观看| 亚洲午夜在线| 亚洲国产福利在线| 欧美在线观看天堂一区二区三区| 亚洲激情婷婷| 国产自产v一区二区三区c| 欧美激情一二三区| 久久嫩草精品久久久精品| 在线综合亚洲欧美在线视频| 欧美aa国产视频| 久久精品成人| 性久久久久久久| 中文亚洲免费| 亚洲精品一区中文| 怡红院精品视频| 国产女主播一区二区| 欧美区一区二区三区| 久久永久免费| 欧美一区二区三区在线| 亚洲中午字幕| 亚洲午夜av电影| 亚洲午夜久久久久久久久电影网| 亚洲第一毛片|