日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

【学习笔记】React+React全家桶学习笔记

發(fā)布時間:2023/12/8 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【学习笔记】React+React全家桶学习笔记 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

文章目錄

  • 1 為什么要使用React
  • 2 React的定義
  • 3 React的三大特性
  • 4 React入門
    • 4.1 hello_react
    • 4.2 虛擬DOM的創(chuàng)建
    • 4.3 JSX
    • 4.4 模塊與組件,模塊化與組件化的理解
  • 5 React面向組件編程
    • 5.1 基本理解和使用
    • 5.2 組件實例的三大核心屬性
      • 5.2.1 state
      • 5.2.2 props
      • 5.2.3 ref
    • 5.3 React中的事件處理
    • 5.4 React中收集表單數(shù)據(jù)
      • 5.4.1 非受控組件與非受控組件
    • 5.5 組件的 生命周期
      • 5.5.1 效果
      • 5.5.2. 掛載與卸載
      • 5.5.3 理解
      • 5.5.4 生命周期流程圖(舊)
      • 5.5.5 生命周期流程圖(新)
      • 5.5.6 重要勾子和即將廢棄的勾子
    • 5.6 虛擬DOM與DOM Diffing算法
  • 6 React應用(基于React腳手架)
    • 6.1 使用create-react-app創(chuàng)建react應用
      • 6.1.1 react腳手架
      • 6.1.2 創(chuàng)建項目并啟動
      • 6.1.3 react腳手架項目結構
      • 6.1.4 功能界面的組件化編碼流程(通用)
    • 6.2 react ajax
      • 6.2.1 理解
      • 6.2.2 axios
      • 6.2.3 react腳手架配置代理總結
      • 6.2.4 消息訂閱-發(fā)布機制
      • 6.2.5 擴展:Fetch(關注分離思想)
  • 7 React路由
    • 7.1 相關理解
      • 7.1.1 SPA 的理解
      • 7.1.2 路由的理解
      • 7.1 .3 react-router-dom的理解
    • 7.2 react-router-dom相關API
      • 7.2.1 內置組件
      • 7.2.2. 其它
  • 8 代碼
  • 9 參考

1 為什么要使用React

  • 開發(fā)迅速。React組件化的特性使得React可以在項目中大量復用封裝好的組件,提高代碼的復用率,減少了重復寫相同代碼的繁瑣而無聊的工作
    • 原生的JavaScript操作DOM繁瑣,效率低(DOM-API操作UI)
    • 使用JavaScript,包括jQuery直接操作DOM,瀏覽器會進行大量的重繪和重排(雖然jQuery簡化了操作DOM的步驟,但依然效率低下)
    • 原生的JavaScript沒有組件化編碼方案,代碼復用率低
  • 生態(tài)相對完善。React 起源于 Facebook 的內部項目,具有相對穩(wěn)定的維護,周邊生態(tài)相對完善,像各種的UI庫,路由庫等,可以在更少的時間內完成更多的工作。
  • 有大公司作為背書。除了React的開發(fā)公司Faceboook大量使用React外,國內外還有很多大公司也廣泛應用React,在國外有Paypal,Airbnb等,在國內有阿里,騰訊,字節(jié)跳動等。
  • 有強大的開源社區(qū)。開源項目的社區(qū)非常重要,在社區(qū)開發(fā)者的貢獻下會讓一些開源項目變得越來越好,項目的issue的解決速度也會得到提升,同時還會提供大量的周邊技術工具和技術博客。
  • 2 React的定義

    React的定義:用于構建用戶界面的JavaScript庫。
    關鍵字

  • 構建用戶界面:說明React專注于視圖的構建,既不是一個請求庫,也不是一個打包工具,而是主要提供UI層面的解決方案。
  • JavaScript庫:這說明React并不是一個框架,并不能解決項目中的所有問題,為了在項目中使用它,需要結合其他的庫,例如Redux/React-router等來協(xié)助提供完整的解決方案。在這些周邊生態(tài)的配合下才能組合成一個框架
  • 換句話來說,React所做的有三步

  • 發(fā)送請求獲得數(shù)據(jù)
  • 處理數(shù)據(jù)(過濾,整理格式等)
  • 操作DOM呈現(xiàn)頁面
  • 也就是說React也可以定義為一個將數(shù)據(jù)渲染為HTML視圖的開源JavaScript庫。

    3 React的三大特性

  • 聲明式編程
  • 命令式編程 VS 聲明式編程:

    簡單來說,命令式編程就是通過代碼來告訴計算機去做什么。

    而聲明式編程是通過代碼來告訴計算機你想要做什么,讓計算機想出如何去做。

    舉個生活中的例子就是:
    命令式編程:我想喝一個冰可樂,然后我就會對身邊的XXX說:“XXX,你去廚房,打開冰箱,拿出一瓶冰可樂,打開之后送過來給我。”
    聲明式編程:我想喝一個冰可樂,然后我就會對身邊的XXX說:“XXX,我想喝冰可樂。”而具體他是怎么拿到的冰可樂,怎么送過來的,是下樓買的還是在冰箱里拿的,我并不關心,我只關心我喝冰可樂的需求是否得到了滿足。

    用代碼來舉個例子:
    如果我要在界面上展示一個按鈕,并且點擊按鈕后會改變該按鈕的class。

    用DOM編程寫的代碼就是命令式編程:首先你要指揮瀏覽器,第一步先要找到id為container的節(jié)點,然后創(chuàng)建一個button element,接著給這個button添加一個class name,然后添加一個點擊事件,最后將button添加到container節(jié)點里。這整個過程每一步操作都是命令式的,一步一步告訴瀏覽器要做什么。

    const container = document. getElementById ( "container" ); const btn = document.createElement ("button");btn.className = "btn red " ; btn.textContent = "Demo" ;btn.onclick = function ( ) {if ( this.classList.contains ( "red" ) ) {this.classList.remove( "red" );this.classList.add ( "blue" );}else {this.classList.remove( "blue" );this.classList.add ( "red" );} }; container.appendChild( btn);

    而要實現(xiàn)相同功能,采用聲明式編程的React就簡單得多了。
    首先我們定義一個Button組件,在render函數(shù)里通過返回一個類似HTML的數(shù)據(jù)結構,告訴React我要渲染一個Button,它是id為container的子節(jié)點。Button上的ClassName是動態(tài)變化的,當點擊按鈕時class要改變,這樣就可以了。至于render什么時候被執(zhí)行,是如何渲染到頁面上的,點擊按鈕之后classname是如何更新的,這些都不需要你關心,你只需要告訴React你希望當前的UI應該是一個什么樣的狀態(tài)就可以了。

    class Button extends React. Component {state = { color: "red" };handleChange =()=> {const color = this.state.color == "red" ? "blue" : "red" ;this.setState({ color });};render( ) {return (<div id="container"><buttonclassName={ `btn ${this.state.color}` }onclick={this.handleChange}>Demo</button></div>);} }
  • 組件化:React提供了一種全新的語法擴展,JSX。JSX創(chuàng)造性地將渲染邏輯和UI邏輯結合在了一起,而這個結合體在React中就被稱為組件。一個頁面由多個組件組成,甚至整個應用都可以視為一個組件,只不過是最大的組件。組件可以層層嵌套,一個組件可以由多個組件組成,一個大的組件由很多個小組件組成,這些小組件也有可能由更小的組件組成。同一個組件可能會被使用在不同的地方。

    組件化的出現(xiàn)大幅度地提升了代碼地復用率,同時也改變了前端開發(fā)人員的一個編程思維
  • 一次學會,隨處編寫:這句話的意思不是學會了想寫什么就可以寫什么,也不是說寫一次想在哪里跑就在哪里跑,而是說學會后可以在很多地方使用React的語法來寫代碼,比如配合React DOM來編寫web端的頁面,配合React Native來寫手機客戶端APP,配合React 360開發(fā)VR界面等。

    React的靈活性是由于它自身的定位決定的。React是一個用于構建用戶界面的JS庫,對于React來說,這里的用戶界面是一個抽象的虛擬的用戶界面,其實就是一個描述頁面狀態(tài)的數(shù)據(jù)結構。web頁面,移動客戶端頁面,VR界面都是用戶界面,只要配合相應的渲染器就能在不同的平臺中展示正確的UI界面。

    通俗來說,我們可以把React的執(zhí)行結果想象成一個視頻文件數(shù)據(jù),在不同的播放器設備,我們通過轉換器將視頻編譯成不同的格式來讓他們在不同的播放器上正常地播放。所以在寫web端React時我們要額外引入React DOM來做渲染。
  • 此外,React使用虛擬DOM+優(yōu)秀的Diffing算法,盡量減少與真實DOM的交互,最小化頁面重繪

    4 React入門

    4.1 hello_react

    4.2 虛擬DOM的創(chuàng)建

  • 創(chuàng)建虛擬DOM的兩種方式

    • 純JS方式(一般不用,過于繁瑣)
    • JSX方式(簡單方便,最終由babel翻譯成js的形式,與用js寫的結果一樣)
  • 虛擬DOM和真實DOM

    • React提供一些API來創(chuàng)建一種“特別”的一般js對象

      const VDOM = React.createElement('xx',{id:'xx'},'xx')///依次為標簽名,標簽屬性和標簽內容

      上面創(chuàng)建的就是一個簡單的虛擬DOM對象

      [外鏈圖片轉存失敗,源站可能有防盜鏈機制,建議將圖片保存下來直接上傳(img-nCawKD9t-1624953908993)(https://i.loli.net/2021/04/25/qwd6egtIJMapLmA.png)]

    • 我們編碼時基本只需要操作react的虛擬DOM相關數(shù)據(jù),react就會轉換為真實的DOM

    關于虛擬DOM總結:

  • 本質是Object類型的對象(一般對象)
  • 虛擬DOM比較“輕”,真實DOM比較“重”,因為虛擬DOM是React內部在用,無需真實DOM上那么多的屬性
  • 虛擬DOM對象最終都會被React轉換為真實DOM,呈現(xiàn)在頁面上
  • 4.3 JSX

    鏈接:JSX基本語法規(guī)則

  • 全稱: JavaScript XML

  • react定義的一種類似于XML的JS擴展語法: JS + XML,本質上還是JavaScript

  • 是**React.createElement(component, props, …children)**方法的語法糖

  • 作用:用來簡化創(chuàng)建虛擬DOM

    • 寫法:var ele =

      Hello JSX!

    • 它不是字符串(不要加引號),也不是HTML/XML標簽
    • 它最終產(chǎn)生的就是一個js對象
  • 標簽名任意:HTML標簽或其他標簽

  • 標簽屬性隨意:HTML標簽屬性或其它

  • 基本語法規(guī)則

    • 標簽首字母

      ? (1)若小寫字母開頭,則將該標簽轉為HTML中同名元素,若HTML中無該標簽對應的同名元素,則報錯。

      ? (2)若大寫字母開頭,則react就去渲染對用的組件,若組件沒有定義,則報錯

    • 標簽中的js表達式必須用{ }包含

      一定要區(qū)分:【JS語句(代碼)】與【js表達式】

    • 表達式:一個表達式會產(chǎn)生一個值,可以放在任何一個需要值的地方

      下面這些都是表達式:

      • a
      • a+b
      • demo(1) //函數(shù)調用表達式
      • arr.map()
      • function test() { }
    • 語句(代碼):不產(chǎn)生值

      ? 下面這些都是語句(代碼):

      • if(){}
      • for(){}
      • switch(){case:xxx}
    • 注釋需要寫在花括號{}中

    • 樣式的類名指定不要寫class,要寫className

    • 內聯(lián)樣式要用style={{key:value}}的形式寫第一個{}表示里面是一個js表達式,第二個{}表示里面是一個鍵值對,里面要寫小駝峰的形式, 比如font-size要寫成fontSize

      <span style={{color:’#e0e0e0’, fontSize:18} }> myData

    • 虛擬DOM只能有一個根標簽,有多個標簽時,可用一個div包起來

    • 標簽必須閉合

  • babel.js的作用
    • 瀏覽器不能直接解析JSX代碼, 需要babel轉譯為純JS的代碼才能運行
    • 只要用了JSX,都要加上type=“text/babel”, 聲明需要babel來處理

    4.4 模塊與組件,模塊化與組件化的理解

  • 模塊
    • 理解:向外提供特定功能的js程序,一般就是一個js文件
    • 為什么要拆成模塊:因為隨著業(yè)務邏輯增加,代碼越來越多且復雜
    • 作用:服用js,簡化js的編寫,提高js運行效率
  • 組件
    • 理解:用來實現(xiàn)局部功能的代碼和資源的集合(html/css/js/image等等)
    • 為什么一個界面的功能很復雜,不可能寫成一整塊,要分成一塊塊寫,然后拼起來
    • 作用:復用編碼,簡化項目編碼,提高運行效率
  • 模塊化
  • 當一個應用的js都是以模塊來編寫,這個應用就是一個模塊化的應用

  • 組件化
  • 當應用是以多組件的方式實現(xiàn),這個應用就是一個組件化的應用

    5 React面向組件編程

    5.1 基本理解和使用

    組件的類型

  • 函數(shù)式組件:用函數(shù)定義的組件,適用于簡單組件的定義(沒有實例,this=undefined)
  • ? 注意:

    ? (1)組件名必須首字母大寫

    ? (2)虛擬DOM元素只能有一個根元素

    ? (3)虛擬DOM元素必須有結束標簽

  • 類式組件:用類定義的組件,適用于復雜組件的定義(有實例)
  • 簡單組件:無狀態(tài)的組件

    復雜組件:有狀態(tài)(state)的組件

    狀態(tài):舉例子說

    • 人是有狀態(tài)的,比如今天的精神如何,人的狀態(tài)會影響人的行為
    • 組件也是有狀態(tài)的,組件的狀態(tài)驅動頁面,數(shù)據(jù)放在狀態(tài)里

    5.2 組件實例的三大核心屬性

    5.2.1 state

  • 理解:
    • state是組件對象最重要的屬性, 值是==對象(==可以包含多個key-value的組合),用{}包裹
    • 組件被稱為"狀態(tài)機", 通過更新組件的state來更新對應的頁面顯示(重新渲染組件)
  • 注意:
    • 組件中render方法中的this為組件實例對象
    • 組件自定義的方法中this為undefined(作為事件的回調使用),如何解決?
      • a) 強制綁定this: 通過函數(shù)對象的bind()
      • b) 箭頭函數(shù)【要寫成賦值語句+箭頭函數(shù)的形式,類里面不支持function(){ }這種形式】
    • 狀態(tài)數(shù)據(jù),不能直接修改或更新,要用setState

    5.2.2 props

  • 理解:
    • 每個組件對象都會有props(properties的簡寫)屬性
    • 組件標簽的所有屬性都保存在props中
  • 作用
    • 通過標簽屬性從組件外向組件內傳遞變化的數(shù)據(jù)
    • 注意: 組件內部不要修改props數(shù)據(jù)
  • 編碼操作
    • 內部讀取某個屬性值: this.props.name

    • 對props中的屬性值進行類型限制和必要性限制

    • 第一種方式(React v15.5 開始已棄用):

      Person.propTypes = {name: React.PropTypes.string.isRequired,age: React.PropTypes.number }
    • 第二種方式(新):使用prop-types庫進限制(需要引入prop-types庫)

      Person.propTypes = {name: PropTypes.string.isRequired,age: PropTypes.number. }
    • 擴展屬性:將對象的所有屬性通過props傳遞:<Person {…person}/>

    • 默認屬性值:

    Person.defaultProps = {age: 18,sex:'男' }
    • 組件類的構造函數(shù)

      constructor(props){super(props)console.log(props)//打印所有屬性 }

    5.2.3 ref

  • 理解:組件內的標簽可以定義ref屬性來標識自己

  • 編碼

    • 字符串形式的ref:(已經(jīng)不被react推薦使用)官方說明

      <input ref = 'input1'/>
    • 回調形式的ref

      <input ref={(c)=>{this.input1 = c}}
    • createRef創(chuàng)建ref容器

    myRef = React.createRef() ; <input ref={this.myRef}/>

    5.3 React中的事件處理

  • 通過onXxx屬性指定處理函數(shù)(注意大小寫,與原生的js區(qū)分開)

    ? a) React使用的是自定義(合成)事件, 而不是使用的原生DOM事件 ——目的是為了更好的兼容性

    ? b) React中的事件是通過事件委托方式處理的(委托給組件最外層的元素) ——目的是為了高效

  • 通過event.target得到發(fā)生事件的DOM元素對象 ——為了避免過度使用ref

  • 不要過度使用ref,當發(fā)生事件的DOM正好是要操作的DOM元素時可以用event.target的形式

    5.4 React中收集表單數(shù)據(jù)

    5.4.1 非受控組件與非受控組件

    非受控組件:現(xiàn)用現(xiàn)取(ref)

    受控組件:隨著輸入維護狀態(tài)為受控組件(onChange , setState)

    5.5 組件的 生命周期

    5.5.1 效果

    需求:定義組件實現(xiàn)以下功能:

  • 讓指定的文本做顯示 / 隱藏的漸變動畫
  • 從完全可見,到徹底消失,耗時2S
  • 點擊“不活了”按鈕從界面中卸載組件
  • 5.5.2. 掛載與卸載

    掛載:mount。當 組件第一次被渲染到 DOM 中的時候,就為其設置一個計時器。這在 React 中被稱為“掛載(mount)”。

    卸載:unmount。同時,當 DOM 中 組件被刪除的時候,應該清除計時器。這在 React 中被稱為“卸載(unmount)”

    5.5.3 理解

  • 組件從創(chuàng)建到死亡它會經(jīng)歷一些特定的階段。
  • React組件中包含一系列勾子函數(shù)(生命周期回調函數(shù)), 會在特定的時刻調用。
  • 我們在定義組件時,會在特定的生命周期回調函數(shù)中,做特定的工作。
  • 5.5.4 生命周期流程圖(舊)

    生命周期的三個階段(舊)

  • 初始化階段: 由ReactDOM.render()觸發(fā)—初次渲染

    ? 1). constructor()

    ? 2). componentWillMount()

    ? 3). render()

    ? 4). componentDidMount() = = = =>常用,一般在這個鉤子中做一些初始化的事,例如開啟定時器、 發(fā)送網(wǎng)絡請求、訂閱消息、開啟監(jiān)聽, 發(fā)送ajax請求等

  • 更新階段: 由組件內部this.setSate()或父組件重新render觸發(fā)

    ? 1). shouldComponentUpdate()

    ? 2). componentWillUpdate()

    ? 3). render() = = = =>必須要使用

    ? 4). componentDidUpdate()

  • 卸載組件: 由ReactDOM.unmountComponentAtNode()觸發(fā)

    ? 1). componentWillUnmount() = = = =>常用,一般在這個鉤子做一些收尾的工作,例如,關閉定時 器、取消訂閱消息

  • 5.5.5 生命周期流程圖(新)

    生命周期的三個階段(新)

    **1. ** 初始化階段: 由ReactDOM.render()觸發(fā)—初次渲染

    ? constructor()

    getDerivedStateFromProps(新增,很少用,上官網(wǎng)了解即可)

    ? (此方法適用于罕見的用例,即 state 的值在任何時候都取決于 props)

    ? render()

    ? componentDidMount()

  • 更新階段: 由組件內部this.setSate()或父組件重新render觸發(fā)

    ? getDerivedStateFromProps

    ? shouldComponentUpdate()

    render()

    **getSnapshotBeforeUpdate ** 在更新之前獲取快照,有點實用意義

    componentDidUpdate()

    **3. ** 卸載組件: 由ReactDOM.unmountComponentAtNode()觸發(fā)

  • ? componentWillUnmount()

    5.5.6 重要勾子和即將廢棄的勾子

  • 重要勾子
    • render:必須要使用,初始化渲染或更新渲染調用
    • componentDidMount:一般在這個鉤子中做一些初始化的事,例如開啟定時器、 發(fā)送網(wǎng)絡請求、訂閱消息,開啟監(jiān)聽, 發(fā)送ajax請求等
    • componentWillUnmount:做一些收尾工作, 如: 清理定時器,取消訂閱等
  • 即將廢棄的勾子
    • componentWillMount
    • componentWillReceiveProps
    • componentWillUpdate
  • 16版本能正常使用,17版本使用會出現(xiàn)警告,下一個大版本需要加上UNSAFE_前綴才能使用,以后可能會被徹底廢棄,不建議使用。

    5.6 虛擬DOM與DOM Diffing算法

  • 基本原理圖
  • 經(jīng)典面試題:

    1). react/vue中的key有什么作用?(key的內部原理是什么?)

    2). 為什么遍歷列表時,key最好不要用index?

  • 虛擬DOM中key的作用:

    1). 簡單地說: key是虛擬DOM對象的標識, 在更新顯示時key起著極其重要的作用。

    2). 詳細地·說: 當狀態(tài)中的數(shù)據(jù)發(fā)生變化時,react會根據(jù)【新數(shù)據(jù)】生成【新的虛擬DOM】, 隨后React進行【新虛擬DOM】與【舊虛擬DOM】的diff比較,比較規(guī)則如下:

  • ? a. 舊虛擬DOM中找到了與新虛擬DOM相同的key:

    ? (1).若虛擬DOM中內容沒變, 直接使用之前的真實DOM

    ? (2).若虛擬DOM中內容變了, 則生成新的真實DOM,隨后替換掉頁面中之前的真實DOM

    ? b. 舊虛擬DOM中未找到與新虛擬DOM相同的key

    ? 根據(jù)數(shù)據(jù)創(chuàng)建新的真實DOM,隨后渲染到到頁面

  • 用index作為key可能會引發(fā)的問題:
  • ? 1) 若對數(shù)據(jù)進行:逆序添加、逆序刪除等破壞順序操作:

    ? 會產(chǎn)生沒有必要的真實DOM更新 ==> 界面效果沒問題, 但效率低。

    ? 2.)如果結構中還包含輸入類的DOM:

    ? 會產(chǎn)生錯誤DOM更新 ==> 界面有問題。

    ? 3) ==注意!==如果不存在對數(shù)據(jù)的逆序添加、逆序刪除等破壞順序操作, 僅用于渲染列表用于展 示,使用index作為key是沒有問題的。

    ?

    ? 3. 開發(fā)中如何選擇key?:

    ? 1) 最好使用每條數(shù)據(jù)的唯一標識作為key, 比如id、手機號、身份證號、學號等唯一值。

    ? 2) 如果確定只是簡單的展示數(shù)據(jù),用index也是可以的。

    6 React應用(基于React腳手架)

    6.1 使用create-react-app創(chuàng)建react應用

    6.1.1 react腳手架

  • xxx腳手架: 用來幫助程序員快速創(chuàng)建一個基于xxx庫的模板項目
    1)包含了所有需要的配置(語法檢查、jsx編譯、devServer…)

    2) 下載好了所有相關的依賴、

    3)可以直接運行一個簡單效果

  • react提供了一個用于創(chuàng)建react項目的腳手架庫: create-react-app

  • 項目的整體技術架構為: react + webpack + es6 + eslint

  • 使用腳手架開發(fā)的項目的特點: 模塊化, 組件化, 工程化

  • 6.1.2 創(chuàng)建項目并啟動

    第一步,全局安裝:npm i -g create-react-app

    第二步,切換到想創(chuàng)項目的目錄,使用命令:create-react-app hello-react

    第三步,進入項目文件夾:cd hello-react

    第四步,啟動項目:npm start

    6.1.3 react腳手架項目結構

    public ---- 靜態(tài)資源文件夾

    ? favicon.icon ------ 網(wǎng)站頁簽圖標(一定要是icon格式)

    ? index.html -------- 主頁面(整個項目只有這一個html文件,SPA應用,即單頁面應用)

    ? logo192.png ------- logo圖

    ? logo512.png ------- logo圖

    ? manifest.json ----- 應用加殼的配置文件

    ? robots.txt -------- 爬蟲協(xié)議文件

    src ---- 源碼文件夾

    ? App.css -------- App組件的樣式

    ? App.js --------- App 組件

    ? App.test.js ---- 用于給App做測試(幾乎不用)

    ? index.css ------ 樣式

    ? index.js ------- 入口文件

    ? logo.svg ------- logo圖

    ? reportWebVitals.js

    ? — 頁面性能分析文件(需要web-vitals庫的支持)

    ? setupTests.js

    ? ---- 組件單元測試的文件(需要jest-dom庫的支持)

    6.1.4 功能界面的組件化編碼流程(通用)

  • 拆分組件: 拆分界面,抽取組件

  • 實現(xiàn)靜態(tài)組件: 使用組件實現(xiàn)靜態(tài)頁面效果

  • 實現(xiàn)動態(tài)組件

    ? 3.1 動態(tài)顯示初始化數(shù)據(jù)

    ? 3.1.1 數(shù)據(jù)類型

    ? 3.1.2 數(shù)據(jù)名稱

    ? 3.1.3 保存在哪個組件?

    ? 3.2 交互(從綁定事件監(jiān)聽開始)

  • 6.2 react ajax

    6.2.1 理解

  • 注意
    • React本身只關注于界面, 并不包含發(fā)送ajax請求的代碼

    • 前端應用需要通過ajax請求與后臺進行交互(json數(shù)據(jù))

    • react應用中需要集成第三方ajax庫(或自己封裝)

  • 常用的ajax請求庫
    • Query: 比較重, 如果需要另外引入不建議使用

    • axios: 輕量級, 建議使用

    ? 1) 封裝XmlHttpRequest對象的ajax

    ? 2) promise風格

    ? 3) 可以用在瀏覽器端和node服務器端

    6.2.2 axios

  • 文檔
  • 相關API
    • GET請求

      axios.get('/user?ID=12345').then(function (response) {console.log(response.data);}).catch(function (error) {console.log(error);});axios.get('/user', {params: {ID: 12345}}).then(function (response) {console.log(response);}).catch(function (error) {console.log(error);});
    • POST請求

      axios.post('/user', {firstName: 'Fred',lastName: 'Flintstone' }) .then(function (response) { console.log(response); }) .catch(function (error) { console.log(error); });

    6.2.3 react腳手架配置代理總結

  • 方法1

    ? 在package.json中追加如下配置

    "proxy":"http://localhost:5000"

    ? 說明:

    ? 1)優(yōu)點:配置簡單,前端請求資源時可以不加任何前綴。

    ? 2)缺點:不能配置多個代理。

    ? 3)工作方式:上述方式配置代理,當請求了3000不存在的資源時,那么該請求會轉發(fā)給5000 (優(yōu)先匹配前端資源)

  • 方法2:

    ? 1)第一步:創(chuàng)建代理配置文件

    ? 在src下創(chuàng)建配置文件:src/setupProxy.js

    ? 2) 編寫setupProxy.js配置具體代理規(guī)則:

    const proxy = require('http-proxy-middleware')module.exports = function(app) {app.use(proxy('/api1', { //api1是需要轉發(fā)的請求(所有帶有/api1前綴的請求都會轉發(fā)給5000)target: 'http://localhost:5000', //配置轉發(fā)目標地址(能返回數(shù)據(jù)的服務器地址)changeOrigin: true, //控制服務器接收到的請求頭中host字段的值/*changeOrigin設置為true時,服務器收到的請求頭中的host為:localhost:5000changeOrigin設置為false時,服務器收到的請求頭中的host為:localhost:3000changeOrigin默認值為false,但我們一般將changeOrigin值設為true*/pathRewrite: {'^/api1': ''} //去除請求前綴,保證交給后臺服務器的是正常請求地址(必須配置)}),proxy('/api2', { target: 'http://localhost:5001',changeOrigin: true,pathRewrite: {'^/api2': ''}}))}

    ? 說明:

  • 優(yōu)點:可以配置多個代理,可以靈活的控制請求是否走代理。
  • 缺點:配置繁瑣,前端請求資源時必須加前綴。
  • 6.2.4 消息訂閱-發(fā)布機制

  • 工具庫: PubSubJS

  • 下載: npm install pubsub-js --save

  • 使用:

    ? 1) import PubSub from ‘pubsub-js’ //引入

    ? 2) PubSub.subscribe(‘delete’, function(data){ }); //訂閱

    ? 3) PubSub.publish(‘delete’, data) //發(fā)布消息

  • 理解

    ? 1)先訂閱,再發(fā)布(理解:有一種隔空對話的感覺)

    ? 2)適用于任意組件間通信

  • ? 3)要在組件的componentWillUnmount中取消訂閱

    6.2.5 擴展:Fetch(關注分離思想)

  • 文檔

    1) https://github.github.io/fetch/

    2) https://segmentfault.com/a/1190000003810652

  • 特點

    1)fetch: 原生函數(shù),不再使用XmlHttpRequest對象提交ajax請求(axios和jQuery都是對XmlHttpRequset的封裝)

    2)老版本瀏覽器可能不支持

  • 相關API

    1)GET請求

    fetch(url).then(function(response) {return response.json()}).then(function(data) {console.log(data)}).catch(function(e) {console.log(e)});

    2)POST請求

    fetch(url, {method: "POST",body: JSON.stringify(data),}).then(function(data) {console.log(data)}).catch(function(e) {console.log(e)})
  • 7 React路由

    7.1 相關理解

    7.1.1 SPA 的理解

  • 單頁Web應用(single page web application,SPA)。

  • 整個應用只有==一個完整的頁面==。

  • 點擊頁面中的鏈接==不會刷新頁面,只會做頁面的局部更新。==

  • 數(shù)據(jù)都需要通過ajax請求獲取, 并在前端異步展現(xiàn)。

  • 7.1.2 路由的理解

    1. 什么是路由?

    • 一個路由就是一個映射關系(key:value)

    • key為路徑, value可能是function或component

    2. 路由分類

    ? 1) 后端路由:

    • 理解: value是function, 用來處理客戶端提交的請求。

    • 注冊路由: router.get(path, function(req, res))

    • 工作過程:當node接收到一個請求時, 根據(jù)請求路徑找到匹配的路由, 調用路由中的函數(shù)來處理請求, 返回響應數(shù)據(jù)

    ? 2) 前端路由:

    • 瀏覽器端路由,value是component,用于展示頁面內容。

    • 注冊路由:

    • 工作過程:當瀏覽器的path變?yōu)?test時, 當前路由組件就會變?yōu)門est組件

    7.1 .3 react-router-dom的理解

  • react的一個插件庫。

  • 專門用來實現(xiàn)一個SPA應用。

  • 基于react的項目基本都會用到此庫。

  • 7.2 react-router-dom相關API

    7.2.1 內置組件

  • < BrowserRouter >

  • < HashRouter >

  • < Route >

  • < Redirect >

  • < Link >

  • < NavLink >

  • < Switch >

  • 7.2.2. 其它

  • history對象

  • match對象

  • withRouter函數(shù)

  • 8 代碼

    里面由筆記的markdown版本和源代碼,還有一些其他的學習筆記
    GitHub地址

    9 參考

    尚硅谷React全家桶
    ps:張?zhí)煊砝蠋熤v得超級棒,yysd

    總結

    以上是生活随笔為你收集整理的【学习笔记】React+React全家桶学习笔记的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內容還不錯,歡迎將生活随笔推薦給好友。

    天天爽夜夜爽精品视频婷婷 | 激情电影影院 | 久久免费高清视频 | 四虎影视国产精品免费久久 | 日本动漫做毛片一区二区 | 99精品一级欧美片免费播放 | av观看免费在线 | 亚洲 欧美 综合 在线 精品 | 精品一区二区免费视频 | 久久黄页 | 去干成人网 | 91传媒91久久久 | 欧美一级在线看 | 亚洲天天综合 | 国产免费观看av | 国产精品免费成人 | 亚洲一级二级三级 | 国产破处在线播放 | 999成人免费视频 | 丁香六月婷 | 久久综合桃花 | 日韩av在线免费播放 | 在线a人v观看视频 | 黄色片毛片 | 亚洲亚洲精品在线观看 | 久久久这里有精品 | 中文在线免费视频 | 亚洲黄色在线观看 | 成人h视频在线播放 | 伊人国产在线播放 | 亚洲人成免费 | 亚洲国产精品成人精品 | 91av社区 | 手机在线黄色网址 | 中文字幕免费观看视频 | 欧美精品乱码久久久久久 | 婷婷亚洲五月色综合 | 午夜91视频 | 日韩大片在线播放 | 韩国精品在线观看 | 不卡电影免费在线播放一区 | 国产视频一区在线播放 | 欧美色图另类 | 黄色片视频免费 | 国产精品99免费看 | www黄色软件| 久久久久电影网站 | 黄色小说免费在线观看 | 日韩深夜在线观看 | 久久精品国亚洲 | 人人澡人| 日韩高清成人在线 | 亚洲丝袜中文 | 黄色特级片 | 伊色综合久久之综合久久 | 天天色婷婷 | 欧亚日韩精品一区二区在线 | 永久免费视频国产 | 中文字幕国产亚洲 | 五月婷婷色 | 精品视频 | 伊人国产在线播放 | 国产精品免费观看在线 | 国产精品日韩精品 | 久久久精品视频成人 | 69亚洲精品 | 美州a亚洲一视本频v色道 | 久久久久国产视频 | 国产精品乱码一区二区视频 | 亚洲乱码久久 | 怡红院成人在线 | 久久久91精品国产一区二区三区 | 99精品免费在线观看 | 国产精品手机在线播放 | 国产无遮挡又黄又爽馒头漫画 | 99色资源 | 国产一区二区三区在线免费观看 | 69av视频在线观看 | 精品国产亚洲一区二区麻豆 | 日本不卡123 | 国产在线不卡视频 | 91精品国产三级a在线观看 | 国产午夜精品一区二区三区欧美 | 日本久久久精品视频 | 操操日| 国产一区二区电影在线观看 | 人人超碰人人 | 中文字幕一区二区三区四区视频 | 亚洲国产精品久久久 | 91在线免费看片 | 国产精品午夜av | av观看久久久 | 亚洲精品黄网站 | 免费在线观看不卡av | 中文字幕在线一区二区三区 | 深爱激情综合网 | zzijzzij亚洲日本少妇熟睡 | www一起操| 日韩av成人在线观看 | 久草视频在线资源 | 黄色免费av| 深夜国产福利 | 国产人成看黄久久久久久久久 | 在线视频99 | 毛片网在线观看 | 国产精品久久久久久久久久久久久久 | 97视频在线免费 | 日本一区二区三区免费观看 | 国产又粗又猛又色又黄网站 | 激情影院在线 | 国产91成人| 亚洲另类视频在线观看 | 中文字幕在线看视频国产 | 免费一级片在线观看 | 黄色91免费观看 | 国产午夜在线观看 | 国产 一区二区三区 在线 | 丁香久久激情 | 国产精品久久久一区二区三区网站 | 激情黄色av| 欧美一区二区三区在线播放 | 97久久精品午夜一区二区 | 日韩理论在线视频 | 奇米影视777四色米奇影院 | 日韩欧美99 | 91在线中字 | 亚洲黄色影院 | 色999在线| 久久人人爽人人爽人人 | 成年人黄色大片在线 | 国产精品丝袜久久久久久久不卡 | 久久精品日产第一区二区三区乱码 | 99亚洲视频 | 天天草天天干天天 | av免费电影网站 | 免费观看91视频大全 | 97超碰在线久草超碰在线观看 | 国产亚洲婷婷免费 | 99国内精品久久久久久久 | 国产成人av免费在线观看 | 久久久久9999亚洲精品 | 国产最新在线 | 日韩欧美精品一区二区三区经典 | 粉嫩av一区二区三区四区在线观看 | 91日韩在线 | 国产又粗又长又硬免费视频 | 日韩理论片在线观看 | 国产理论免费 | 日日夜夜人人精品 | 久久男人视频 | 久久99久国产精品黄毛片入口 | wwwwww黄| 中文字幕亚洲欧美日韩 | 在线中文字幕电影 | 不卡的av片 | 亚洲精品 在线视频 | 视频 天天草 | 日韩精品一区二区免费 | 国偷自产中文字幕亚洲手机在线 | av国产网站 | 午夜婷婷网 | 天天摸日日摸人人看 | 久久久免费电影 | a电影免费看 | 久久精品欧美一区 | 九九视频免费观看视频精品 | 一区二区高清在线 | 欧美成人影音 | 国产首页| 国产色秀视频 | av+在线播放在线播放 | 一区免费观看 | 一区二区丝袜 | 91成人免费在线 | 国产首页 | 国产精品女同一区二区三区久久夜 | 色狠狠久久av五月综合 | 午夜免费福利视频 | 国产尤物在线观看 | 中文字幕在线观看的网站 | av蜜桃在线 | 三级av免费观看 | 国产免费一区二区三区网站免费 | 亚洲午夜在线视频 | 日日日爽爽爽 | 精品成人在线 | 91av在线播放 | 精品久久一 | 国产精品一区欧美 | 五月花丁香婷婷 | 国产高清第一页 | 天堂黄色片 | 国产精品久久久久久av | 亚洲欧洲视频 | 激情伊人五月天久久综合 | 久久免费精彩视频 | 日本黄色黄网站 | 国产片网站 | 中文字幕网站视频在线 | 五月天婷婷在线观看视频 | 午夜视频在线观看欧美 | 久久精品国产亚洲 | 欧洲一区二区在线观看 | 久久免费高清视频 | 亚州精品天堂中文字幕 | 亚洲视频免费在线看 | 在线观看日韩精品 | 激情网综合 | 97超碰成人 | 久草在线中文888 | 色吧av色av | 午夜精品久久久 | 五月天电影免费在线观看一区 | 午夜精品久久久久久久久久 | 丁香色婷 | 久久福利影视 | 狠狠搞,com| 免费日韩av电影 | 超碰在线免费福利 | 国产麻豆视频在线观看 | 日本精品一区二区三区在线播放视频 | 九九九热 | 玖玖色在线观看 | 韩国精品视频在线观看 | av色图天堂网 | 911国产在线观看 | 麻豆视频在线免费看 | 成人动态视频 | 狠狠狠狠狠色综合 | 国产精品高清免费在线观看 | 久久九九久久九九 | 日韩h在线观看 | 久久99免费 | 久久99国产精品二区护士 | 久草网免费 | 天天操天天射天天爱 | 成人午夜网址 | 97精品国产97久久久久久免费 | 97精品在线观看 | 92av视频| 婷婷激情av| 超级碰碰视频 | 免费看污黄网站 | 三级黄色a | 亚洲网站在线 | 久久人人添人人爽添人人88v | 久久免费资源 | 国产成人三级三级三级97 | 天天激情 | 亚洲精品美女在线观看 | 天天射天天射 | 久久免费国产精品 | 日日夜夜草 | 美女黄色网在线播放 | 日韩av电影免费在线观看 | 成人黄色在线 | 少妇av网| 91成人久久| 欧美日韩视频 | 五月婷婷在线视频观看 | 国产九色在线播放九色 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 亚洲日本国产精品 | 亚洲综合精品在线 | 中文字幕的| 免费在线色视频 | 日本在线观看中文字幕 | 综合精品久久久 | 精品久久久久免费极品大片 | 国产不卡精品视频 | 亚洲理论电影网 | 亚洲黄色激情小说 | 日韩视频中文字幕在线观看 | 天天操天天曰 | 欧美视频在线二区 | 激情 一区二区 | 欧美日韩免费一区二区三区 | 五月婷婷影院 | 亚洲第一中文网 | 99高清视频有精品视频 | 欧美一级看片 | 国产免费av一区二区三区 | 天堂av在线7| 在线观看成人网 | 免费久久99精品国产婷婷六月 | 国产99久久久国产精品免费看 | 成人精品一区二区三区中文字幕 | 嫩草av影院 | 天天干天天干天天射 | 亚洲乱码精品久久久久 | 日韩黄色一区 | 日本公妇在线观看 | 96香蕉视频 | 久久国产美女 | 精品久久久久久综合日本 | 久久久久免费精品国产小说色大师 | 国产网红在线 | 在线观看av免费 | 一区二区三区中文字幕在线观看 | 国产精品高潮呻吟久久久久 | 最新av在线网站 | 天天在线视频色 | 免费福利视频网 | 国产在线不卡一区 | 精品一区二区精品 | 亚洲精品福利在线 | 97在线观看视频免费 | 香蕉网址| 九九热精 | 亚洲欧美日韩国产一区二区三区 | 香蕉影视app| 91av手机在线观看 | 国产a级精品 | 午夜视频在线观看一区 | 成人精品亚洲 | 特片网久久 | 亚洲三级毛片 | 免费av看片| 国产一区二区三区高清播放 | 91成人免费看| 97电影院在线观看 | 成人在线视频观看 | 日韩午夜小视频 | 999ZYZ玖玖资源站永久 | 超碰在线日本 | av免费电影在线观看 | 久久久久久久免费看 | 精品1区二区 | 91av中文| 国产在线视频一区二区三区 | 欧美一区二区三区免费看 | 日韩高清片 | 一区二区精品视频 | 国产乱对白刺激视频在线观看女王 | 丁香五月缴情综合网 | 婷婷六月激情 | 免费黄色特级片 | 中文字幕亚洲不卡 | 在线看v片成人 | 五月婷婷综合色拍 | 中文字幕欧美激情 | 99资源网 | 中文视频在线播放 | 一级黄色在线免费观看 | 人人澡人人草 | 蜜臀av夜夜澡人人爽人人桃色 | 天天爽天天摸 | 亚洲天堂网站 | 亚洲 欧美 变态 国产 另类 | 日日夜夜人人天天 | 婷婷久久国产 | 激情五月在线 | 一区二区中文字幕在线观看 | 99热在线看 | 99在线国产 | 国产成人一级电影 | 黄色精品一区 | 国产又粗又猛又爽又黄的视频先 | 欧美日韩国产亚洲乱码字幕 | 久草综合视频 | 爱色av.com | 毛片基地黄久久久久久天堂 | 国产一区私人高清影院 | 国产亚洲精品电影 | 久久国产精品99久久久久久丝袜 | 国产综合在线视频 | 在线观看久久 | 97超碰人人澡人人爱 | 成人一区影院 | a黄色| 中文字幕乱在线伦视频中文字幕乱码在线 | 99精彩视频| 99色| 成人蜜桃网 | 国产一级片免费播放 | 91亚洲国产成人久久精品网站 | 国产高清视频在线观看 | 国产精品亚洲精品 | www.888.av | 亚洲精品成人免费 | 欧洲精品一区二区 | 视频 天天草 | 久草视频免费在线播放 | 成人黄色短片 | 九九视频在线观看视频6 | 日本黄色a级大片 | 久久久久久久久久影院 | 国产黄色理论片 | 337p日本大胆噜噜噜噜 | 丁香五婷 | 久久人人看 | 亚洲黄色免费电影 | 国产99视频在线观看 | 在线观看免费av网 | 国产午夜精品一区二区三区欧美 | 草久在线视频 | av在线官网 | 在线观看国产www | 五月天婷婷综合 | 国产色在线观看 | 狠狠色噜噜狠狠狠合久 | 色噜噜在线观看视频 | 日韩区视频 | 美女在线免费视频 | 亚州成人av在线 | 丁香 婷婷 激情 | 中文字幕文字幕一区二区 | 成人黄视频 | 国产精品99久久久久久小说 | 涩涩资源网 | 成人永久免费 | 国产手机视频在线 | www.夜夜爽 | 激情视频区 | 在线小视频 | 99久久久久| 99久久精品免费看国产免费软件 | 亚洲乱码在线观看 | 国产又粗又长又硬免费视频 | 日韩三区在线观看 | 波多野结衣在线观看一区二区三区 | 西西www444 | 最近中文字幕久久 | 日韩精品一区二区三区不卡 | 人人舔人人爱 | 国产日韩在线看 | 久久综合精品国产一区二区三区 | 亚洲国产伊人 | 一区二区三区四区五区六区 | 国产精品成人一区二区三区吃奶 | 国际av在线 | 日本中文字幕在线看 | 欧美激情综合五月色丁香 | 午夜精品中文字幕 | 中国一 片免费观看 | 国产手机av | 欧美日韩视频在线观看免费 | 日本免费久久高清视频 | 亚洲精品99久久久久久 | 亚洲在线网址 | 成人sm另类专区 | 天堂av在线网站 | 热久久这里只有精品 | 中文字幕亚洲情99在线 | 中文字幕专区高清在线观看 | 白丝av在线 | 操操操人人| 亚洲一区尤物 | 91福利视频免费观看 | 四虎在线免费观看 | 精品99999| 97人人模人人爽人人喊中文字 | 九九热免费视频在线观看 | 四虎4hu永久免费 | 一级做a爱片性色毛片www | 国产成年免费视频 | 久久午夜电影院 | 色在线视频 | 国产精品99久久免费观看 | 久久国产影视 | 成人av免费在线观看 | 久久久久久久久久久影院 | 夜夜婷婷| 欧美激情综合五月色丁香小说 | 激情综合站 | www视频免费在线观看 | 99热在线国产精品 | 欧美天天射 | 999电影免费在线观看2020 | 久久精品国产一区二区 | 天天爱天天插 | 久久成人资源 | 久草免费在线视频观看 | 怡春院av | 久久精品4 | 天天操天天爱天天爽 | 日韩黄色av网站 | 福利视频一区二区 | 天天操天天艹 | 999成人国产 | 在线观看视频你懂得 | 国产精品字幕 | 国产精品免费一区二区三区在线观看 | 国产精品久久久久久久久久久免费 | 久久综合久久综合这里只有精品 | 中文字幕在线一二 | 精品视频在线看 | 国产裸体永久免费视频网站 | 国内精品久久久久久中文字幕 | 精品国产免费av | 亚洲精品系列 | 亚洲精品一区中文字幕乱码 | av中文字幕日韩 | 99精品一区 | 97碰碰精品嫩模在线播放 | 欧美日韩国产一区二区在线观看 | 日韩素人在线观看 | 婷婷在线视频观看 | 成人在线播放网站 | 国产成人精品一二三区 | 国产一区二区视频在线 | 亚洲精品一区二区网址 | 日韩色爱| 精品久久久久久久久久久久久久久久久久 | 色插综合| 国产精品va在线观看入 | 91片黄在线观看 | 欧美日韩高清在线一区 | 欧美极品一区二区三区 | 91精品国产91| 黄色一级在线观看 | 欧美日韩免费一区二区 | 欧美在线不卡一区 | 国产又粗又猛又色又黄视频 | 欧美一二三区在线观看 | 中文字幕在线高清 | 久久一区二区三区超碰国产精品 | 成人久久亚洲 | 狠狠干免费 | 91久久人澡人人添人人爽欧美 | 色婷久久 | av免费黄色| 国产在线不卡 | 97超碰超碰| 日韩精品一区二区在线观看视频 | 国产原创av片| 日韩欧美观看 | 国产在线观看你懂得 | 探花视频在线版播放免费观看 | 蜜臀av网址| 一本一道波多野毛片中文在线 | 国产视频2区 | www色com| 久久综合九色综合97婷婷女人 | 国产亚洲va综合人人澡精品 | 午夜精品一二区 | 91人人网| 三级黄色大片在线观看 | 国产色在线观看 | 日韩精品一区二区三区视频播放 | 亚洲爽爽网| 狠狠色丁香婷综合久久 | 在线视频91| 在线观看理论 | 中文字幕在线播放视频 | 97色国产| 99自拍视频在线观看 | 91亚洲精品久久久中文字幕 | 91丨九色丨勾搭 | 亚洲天堂va | 精品网站999www | 日韩中文三级 | 国产精品久久久久毛片大屁完整版 | 999国产 | 亚洲三级在线播放 | 亚洲人成人在线 | 国产精品综合在线 | 中文在线免费视频 | 亚洲欧美日韩精品久久奇米一区 | 久久免费视频精品 | 天天插天天爱 | 91在线视频在线观看 | 精品成人国产 | 国产精品一区二区免费看 | 亚洲日韩中文字幕在线播放 | 成人国产精品av | 亚洲欧美成人综合 | 激情视频91| 亚洲综合激情 | 深爱激情综合 | 91一区二区三区久久久久国产乱 | 欧美在一区| 日韩一区二区在线免费观看 | 国产精品99久久久久久大便 | 国产福利不卡视频 | 久久精品中文字幕少妇 | 激情五月av | 国产精品99蜜臀久久不卡二区 | 三三级黄色片之日韩 | 91麻豆网站 | 日韩久久久久久久 | 国产精品99久久久久久久久 | 91高清在线看 | 黄色av成人在线观看 | 日韩久久午夜一级啪啪 | 激情五月***国产精品 | 久久国产精品久久精品国产演员表 | 丁香激情五月婷婷 | 国产精品国产精品 | 成人黄色大片在线免费观看 | 中文字幕电影网 | 免费三级a | 久久久免费看 | 伊人天天综合 | 啪啪凸凸 | 在线你懂 | 99视频在线精品免费观看2 | 国产精品视频在线看 | 欧美成人精品欧美一级乱 | 国产色秀视频 | 天天拍夜夜拍 | 91在线网址 | 色综合天天视频在线观看 | 国产在线最新 | 中文在线免费观看 | 国产精品久久嫩一区二区免费 | 婷婷五月色综合 | 日韩免费观看视频 | 韩国av免费| 久久一区二区三区国产精品 | 国产99免费视频 | 69国产精品视频 | www.综合网.com | 国产最顶级的黄色片在线免费观看 | 奇米影视8888在线观看大全免费 | 日韩一级片观看 | 日韩小视频| 人人干人人爽 | 看国产黄色片 | 久久久久久久国产精品影院 | 久久视精品 | 伊人影院在线观看 | 91爱看片| 久久久激情网 | 超碰在线人人爱 | 五月婷婷黄色 | 日本韩国欧美在线观看 | 啪啪动态视频 | 在线精品一区二区 | 69久久99精品久久久久婷婷 | 香蕉久草在线 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 日韩免费福利 | 在线观看视频黄 | 在线 国产 亚洲 欧美 | 国产精品黄网站在线观看 | 中文字幕色在线视频 | 免费视频你懂得 | 中文字幕日韩免费视频 | 在线免费观看视频一区二区三区 | 日韩黄色在线电影 | 午夜视频日本 | 成人av免费在线观看 | 久草视频中文 | 在线观看精品一区 | av日韩av| 国产精品久久久久久久久费观看 | 一级片免费在线 | 99热都是精品 | 国产精品久久久久久久婷婷 | 999在线精品 | 人人添人人澡 | 在线观看理论 | 人人澡人人爱 | 国产69熟| 久久免费的视频 | 看片的网址 | 五月天精品视频 | 热久久这里只有精品 | 国产日产亚洲精华av | 久久,天天综合 | 日韩中文字幕亚洲一区二区va在线 | 91麻豆产精品久久久久久 | 成人av免费在线播放 | 国偷自产视频一区二区久 | 操操操干干干 | 欧美日韩精品影院 | 天堂av在线网站 | 人人爽人人舔 | 亚洲精品婷婷 | 夜夜骑首页 | 97色狠狠 | 日本在线观看一区 | 久操中文字幕在线观看 | 夜夜操狠狠干 | 欧美成人日韩 | 国产91综合一区在线观看 | 中文字幕在线观看资源 | 成 人 黄 色视频免费播放 | 看国产黄色片 | 欧美激情亚洲综合 | 国产精品免费久久久 | 亚洲国产精品成人va在线观看 | 在线电影播放 | 一区二区三区免费在线播放 | 婷婷久久丁香 | 伊人午夜| 中文字幕欲求不满 | av一区二区三区在线 | 色www免费视频 | 91麻豆视频 | www.国产视频| 少妇bbw撒尿 | 久久99国产综合精品 | 成人免费观看a | 伊人色**天天综合婷婷 | 色婷婷久久久 | 国产麻豆果冻传媒在线观看 | 日韩一二三 | 中文字幕美女免费在线 | 国产在线精 | 九九在线视频免费观看 | 青春草视频在线播放 | 最近能播放的中文字幕 | 最近中文字幕在线中文高清版 | 国产精品1区2区在线观看 | 超碰在线个人 | 国产一级黄色免费看 | 久久精品久久99精品久久 | 99精品欧美一区二区 | 福利视频导航网址 | 婷婷在线视频观看 | 久草男人天堂 | 久久久网页 | 成年人在线视频观看 | 91精品久久久久久久久久久久久 | 视频在线国产 | 免费在线观看日韩 | 日韩三级免费观看 | 国产精品黄色影片导航在线观看 | 91精品久久久久久综合五月天 | 九九免费精品视频 | 九九热国产视频 | 欧美日韩精品影院 | 激情视频免费在线观看 | 亚洲成人av在线播放 | 国内精品久久久久影院一蜜桃 | 色激情在线 | 久久午夜精品视频 | 日韩成人免费电影 | 国产拍揄自揄精品视频麻豆 | 欧美精品久久久久久久久久久 | 麻豆视屏 | 亚洲精品久久久久久久不卡四虎 | 亚洲免费精品一区二区 | 免费午夜av| 精品视频久久 | 国产精品mv在线观看 | 欧美精品色| 狠狠操欧美 | 碰超在线观看 | 日韩精品在线视频免费观看 | 国产一级在线 | 久久99视频免费 | 东方av免费在线观看 | 色多多污污在线观看 | 在线观看亚洲精品视频 | 水蜜桃亚洲一二三四在线 | 网站在线观看你们懂的 | 色综合婷婷 | 青青久草在线视频 | 亚洲色图激情文学 | 国产亚洲精品日韩在线tv黄 | 欧美日韩精品在线一区二区 | 日本中文字幕系列 | 一区二区三区动漫 | 国产一级淫片免费看 | 国产又粗又长又硬免费视频 | 国产精品美女www爽爽爽视频 | 天天爱天天操天天射 | 手机av在线网站 | 亚洲一区二区三区精品在线观看 | 91av精品 | 夜夜躁天天躁很躁波 | 久久视频国产精品免费视频在线 | 中文字幕在线观看视频网站 | 久久国产视屏 | 国产色视频网站2 | 国产成人99久久亚洲综合精品 | 香蕉网在线观看 | 91亚洲狠狠婷婷综合久久久 | 91精品爽啪蜜夜国产在线播放 | 成人亚洲精品国产www | 久久精品专区 | 96超碰在线| 日本黄色免费网站 | 中文字幕在线观看免费观看 | 成年人网站免费观看 | 亚洲国产美女精品久久久久∴ | 久久久久免费看 | 亚洲欧洲成人精品av97 | 操操爽 | 国产xxxx | 丁香午夜婷婷 | 日韩aⅴ视频 | 蜜臀av网址 | 久久最新网址 | 在线观看av国产 | 亚洲国产精品电影在线观看 | 欧美夫妻性生活电影 | 久久毛片视频 | 国产美女在线精品免费观看 | 在线免费观看成人 | 亚洲精品网站在线 | 亚洲成人黄色网址 | 欧美精品二 | 性色视频在线 | 久久 精品一区 | 成年人视频免费在线播放 | 日av免费 | 国产日韩欧美在线播放 | av中文天堂在线 | 免费亚洲视频 | 亚洲成人资源网 | 久久久精品国产一区二区三区 | 成人av免费在线看 | 久久久久国产精品免费网站 | 韩国视频一区二区三区 | 日韩激情综合 | 91精品无人成人www | 久草精品视频在线播放 | 视频一区二区国产 | 欧美乱码精品一区二区 | 国产一区二区三区免费视频 | 69xxxx欧美| 久久五月天综合 | av一级在线 | 91人人澡人人爽 | 大胆欧美gogo免费视频一二区 | 天天操操 | 国产999精品久久久久久麻豆 | 精品国产黄色片 | 久久歪歪 | 五月婷久久 | 99免费在线视频观看 | 久久久亚洲国产精品麻豆综合天堂 | 国产亚洲精品久久网站 | 国产黄色免费观看 | 五月婷婷在线观看视频 | 成人黄色电影免费观看 | 日韩va欧美va亚洲va久久 | 精品国产一区二区三区四区在线观看 | 精品国产电影一区二区 | 日产乱码一二三区别免费 | 欧美污污视频 | 国产在线国偷精品产拍免费yy | 最新超碰在线 | 久久国产精品系列 | 夜夜躁日日躁狠狠躁 | 亚洲精品男人的天堂 | 97精品超碰一区二区三区 | 中国一级片在线播放 | 亚洲欧美视频在线播放 | 亚洲欧美日韩一二三区 | 亚洲精品动漫成人3d无尽在线 | 精品亚洲免费 | 国产一区二区三区免费在线观看 | 另类老妇性bbwbbw高清 | 99热 精品在线 | 96久久欧美麻豆网站 | 久久黄色影视 | 久久手机免费视频 | 日韩大片在线免费观看 | 亚洲极色 | 狠狠的干狠狠的操 | 久久免费在线观看视频 | 91亚洲精品久久久中文字幕 | 久久99深爱久久99精品 | 欧美精品国产综合久久 | 精品国产乱码一区二 | 国产亚洲视频在线免费观看 | 五月激情姐姐 | 91精品视频网站 | 午夜精品一区二区国产 | 狠狠干中文字幕 | 久久九九九九 | 婷婷丁香社区 | 99c视频高清免费观看 | 亚洲精品视频一二三 | 亚洲毛片视频 | 91成人在线网站 | 久久一线 | 久久影视精品 | 国产成人一区二区在线观看 | 欧美韩国日本在线 | 国产不卡在线观看视频 | 美女视频又黄又免费 | 91久久久久久久一区二区 | 99久久久国产精品美女 | 日韩免费一级电影 | 久久久久亚洲精品中文字幕 | 日韩欧美高清在线 | 久操久| 日韩成年视频 | www亚洲精品 | 色视频在线观看 | 91视频免费国产 | 97视频免费播放 | 亚洲成av人片 | 日日夜夜91 | 成人午夜影院在线观看 | 97在线免费观看 | 欧美a性 | 狠狠干天天射 | 午夜久久影视 | 亚洲精品久久久久久中文传媒 | 草久久久久久 | 97av在线| 伊色综合久久之综合久久 | 日本性动态图 | 国产剧情一区二区在线观看 | 免费在线观看成人小视频 | 日韩久久一区二区 | 成人h视频在线播放 | 国产成人精品av | 久草在线播放视频 | 亚洲精品福利在线 | 久久av影院 | 亚洲精品在线国产 | 韩国一区在线 | 成片免费观看视频999 | 91九色精品女同系列 | 九九免费精品视频在线观看 | 免费观看久久 | 久久精品欧美一区二区三区麻豆 | 麻豆视频免费入口 | 日韩久久久久久久久久久久 | 亚洲国产69 | 国产精品国产亚洲精品看不卡 | a在线视频v视频 | 久久短视频 | 日韩av在线资源 | 色综合天天 | 麻豆国产网站 | 中文字幕在线观看免费高清电影 | 免费大片av | 成人app在线免费观看 | 五月婷婷在线视频 | 国产精品原创视频 | 911香蕉视频 | 欧美日韩国产在线精品 | 欧美国产三区 | 午夜骚影 | 日韩成人免费电影 | 51久久夜色精品国产麻豆 | 久久国产精品久久精品国产演员表 | 青青草国产精品 | 国产网站在线免费观看 | 亚洲综合色视频 | 五月婷婷开心中文字幕 | 在线观看av国产 | 91在线免费观看国产 | 亚洲成av人影院 | 伊人导航 | 91久久黄色| 午夜视频免费播放 | 久久久久免费电影 | 成 人 黄 色 视频免费播放 | 国产视频中文字幕在线观看 | 国产三级精品三级在线观看 | 久久精品九色 | 人人爽人人舔 | 亚洲资源| 激情婷婷在线 | 婷婷六月天在线 | 在线观看色网 | 亚洲精品777 | 国产 欧美 在线 | 天天综合网国产 | 久久久精品欧美 | 免费午夜视频在线观看 | 午夜12点| 婷婷播播网 | 国产精品久久久久久久免费 | 亚洲激情综合 | 在线观看精品黄av片免费 | 国产一区在线视频播放 | 最新av电影网址 | 国产精品久久久久av免费 | 又黄又爽又湿又无遮挡的在线视频 | 免费观看性生交大片3 | 国产精品 中文字幕 亚洲 欧美 | 在线观看www视频 | 香蕉在线影院 | 超碰在线人人艹 | 久久久久久片 | 免费看黄视频 | 四虎国产精品成人免费4hu | 中文字幕一区二区三 | 成人黄在线| 不卡国产在线 | 综合色婷婷 | 亚洲午夜av电影 | 人人爽人人爽人人片av | 99国产精品| 国产精品一区二区三区观看 | 亚洲综合色婷婷 | 狠狠综合久久av | 美女视频免费精品 | 欧美日韩在线网站 | 国产成人福利在线观看 | 成年人在线视频观看 | 973理论片235影院9 | 国产一卡久久电影永久 | 中文字幕一二三区 | 精品国产亚洲日本 | 成人资源网 | 国产精品手机在线观看 |