欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

實(shí)現(xiàn)React單頁應(yīng)用的方法詳解

 更新時(shí)間:2016年08月02日 10:45:00   作者:一個(gè)蘿卜一個(gè)坑  
今天我們來學(xué)習(xí)React是如何構(gòu)建起一個(gè)單頁應(yīng)用的,React作為目前最流行的前端框架之一,其受歡迎程度不容小覷,從這門框架上我們可以學(xué)到許多其他前端框架所缺失的東西,也是其創(chuàng)新性所在的地方,比如虛擬DOM、JSX等。下面一起來看看。

首先在學(xué)習(xí)這門框架前,你需要對(duì)以下知識(shí)有所了解:

     1.原生JS基礎(chǔ)

     2.CSS基礎(chǔ)

     3.npm包管理基礎(chǔ)

     4.webpack構(gòu)建項(xiàng)目基礎(chǔ)

     5.ES6規(guī)范

以上五個(gè)知識(shí)點(diǎn)也是目前學(xué)習(xí)其他前端框架所必須了解的前置任務(wù)。

JS和CSS就不多說了,npm是目前最提倡也是占據(jù)主導(dǎo)地位的包管理工具,還在用bower或者其他工具的童鞋可以考慮下了。而webpack作為新一代打包工具,已經(jīng)在前端打包工具中獨(dú)占鰲頭,和Browserify相比也有很大優(yōu)勢(shì)。至于ES6規(guī)范雖然現(xiàn)在主流瀏覽器還不兼容,但可以使用babel等轉(zhuǎn)換器進(jìn)行轉(zhuǎn)換。

結(jié)合其他的一些主流前端框架,我個(gè)人認(rèn)為構(gòu)建單頁應(yīng)用有這樣三個(gè)基本的東西:組件、路由、狀態(tài)管理。那么接下來我就基于這三者來介紹React,當(dāng)然其中會(huì)穿插一些額外的知識(shí)點(diǎn)。

組件

React的組件撰寫和調(diào)用主要依賴于ES6的模塊化和JSX的語法,以下是一個(gè)例子:

// main.js
import React from 'react'
import { render } from 'react-dom'
import MyComponent from './component.js'
import './main.css'


// 主組件
class MyDemo extends React.Component {
  render() {
    return (
      <div className="box">
        <MyComponent />
      </div>
    )
  }
}

render((
  <MyDemo />
), document.getElementById('app'))


// component.js

// 子組件
import React from 'react'

export default class MyComponent extends React.Component {
  render() {
    return (
      <div>
        <p>這是一個(gè)組件!</p>
      </div>
    )
  }
}


// main.css
.box {
  width: 100%
}

相比Vue.js框架,我個(gè)人認(rèn)為React的組件編寫方式還是沒有Vue來的舒服,組件的css樣式還是脫離在組件外部的,維護(hù)起來也不是很方便。

從這個(gè)例子中我們就可以看到React的虛擬DOM和JSX的特性了。相比其他框架,React的虛擬DOM不僅可以提升頁面的性能,同時(shí)還可以防止XSS攻擊等。關(guān)于虛擬DOM的具體原理這里不作介紹

至于JSX語法則是JS的一種語法糖,我們可以通過這種語法糖來便捷實(shí)現(xiàn)一些功能,這里JSX 把類 XML 的語法轉(zhuǎn)成純粹 JavaScript,XML 元素、屬性和子節(jié)點(diǎn)被轉(zhuǎn)換成 React.createElement 的參數(shù)。類似的JS語法糖還有TypeScript等。

路由

前端路由機(jī)制是目前構(gòu)建單頁應(yīng)用(SPA)最重要的一環(huán)之一。通過前端路由我們可以優(yōu)化用戶體驗(yàn),不需要每次都從服務(wù)器獲取全部數(shù)據(jù),從而快速將頁面展現(xiàn)給用戶。

React路由依賴于React Router。React Router 保持 UI 與 URL 同步。它擁有簡單的 API 與強(qiáng)大的功能例如代碼緩沖加載、動(dòng)態(tài)路由匹配、以及建立正確的位置過渡處理。

下面是一個(gè)React路由的例子:

import React, { Component } from 'react'
import { render } from 'react-dom'
import { Router, Route, IndexRoute, Link, browserHistory } from 'react-router'

const ACTIVE = { color: 'red' }

class App extends Component {
  render() {
    return (
      <div>
        <h1>我的路由</h1>
        <ul>
          <li><Link to="/" activeStyle={ACTIVE}>首頁</Link></li>
          <li><Link to="/users" activeStyle={ACTIVE}>用戶頁</Link></li>
        </ul>
        {this.props.children}
      </div>
    )
  }
}

class Index extends React.Component {
  render() {
    return (
      <div>
        <h2>Index!</h2>
      </div>
    )
  }
}

class Users extends React.Component {
  render() {
    return (
      <div>
        <h2>Users</h2>
      </div>
    )
  }
}

render((
  <Router history={browserHistory}>
    <Route path="/" component={App}>
      <IndexRoute component={Index}/>
      <Route path="users" component={Users}></Route>
    </Route>
  </Router>
), document.getElementById('app'))

這里只列出了React的一種路由寫法。相比其他框架,React路由的語法更加通俗易懂。 

狀態(tài)管理

狀態(tài)管理不是單頁應(yīng)用必須的,使用它能夠幫助我們統(tǒng)一管理各個(gè)狀態(tài)的變更,使整個(gè)項(xiàng)目流程清晰可維護(hù)。React實(shí)現(xiàn)狀態(tài)管理可以使用官方推薦的Redux。

Redux使用的是嚴(yán)格的單向數(shù)據(jù)流。整個(gè)應(yīng)用的 state 被儲(chǔ)存在一棵 object tree 中,并且這個(gè) object tree 只存在于唯一一個(gè) store 中。 

項(xiàng)目實(shí)例

這里我用React寫了一個(gè)單頁網(wǎng)站,頁面如下:

Fetch

因?yàn)樯厦娴膶?shí)例中我用到了Fetch來進(jìn)行Ajax交互,所以這里簡單介紹下Fetch。
我們可以把Fetch作為下一代Ajax技術(shù),它采用了目前流行的 Promise 方式處理。

利用Fetch我們可以這樣寫Ajax進(jìn)行數(shù)據(jù)交互:

// 獲取數(shù)據(jù)方法
  fetchFn = () => {
    fetch('../../data.json')
      .then((res) => { console.log(res.status);return res.json() })
      .then((data) => { this.setState({lists:data.listData}) })
      .catch((e) => { console.log(e.message) })
  }

總結(jié)

學(xué)習(xí)一門框架最重要的并不是學(xué)習(xí)它的技術(shù),而是學(xué)習(xí)其帶來的解決問題的思路。通過React這一門框架的學(xué)習(xí),你可以從它獨(dú)特的新特性中發(fā)掘一種新的思維模式。只有思維層面得到了擴(kuò)展,你才能在前端的海洋里自由翱翔。希望本文對(duì)大家學(xué)習(xí)React有所幫助。

相關(guān)文章

  • ReactJs快速入門教程(精華版)

    ReactJs快速入門教程(精華版)

    React 起源于 Facebook 的內(nèi)部項(xiàng)目,因?yàn)樵摴緦?duì)市場(chǎng)上所有 JavaScript MVC 框架,都不滿意,就決定自己寫一套,用來架設(shè) Instagram 的網(wǎng)站.這篇文章主要介紹了ReactJs快速入門教程(精華版)的相關(guān)資料,需要的朋友可以參考下
    2016-11-11
  • 如何不使用eject修改create-react-app的配置

    如何不使用eject修改create-react-app的配置

    許多剛開始接觸create-react-app框架的同學(xué),不免都會(huì)有個(gè)疑問:如何在不執(zhí)行eject操作的同時(shí),修改create-react-app的配置。
    2021-04-04
  • 基于React實(shí)現(xiàn)搜索GitHub用戶功能

    基于React實(shí)現(xiàn)搜索GitHub用戶功能

    在本篇博客中,我們將介紹如何在 React 應(yīng)用中搜索 GitHub 用戶并顯示他們的信息,文中通過代碼示例給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-02-02
  • React Fiber樹的構(gòu)建和替換過程講解

    React Fiber樹的構(gòu)建和替換過程講解

    React Fiber樹的創(chuàng)建和替換過程運(yùn)用了雙緩存技術(shù),直接將舊的 fiber 樹替換成新的 fiber 樹,這樣做的好處是省去了直接在頁面上渲染時(shí)的計(jì)算時(shí)間,避免計(jì)算量大導(dǎo)致的白屏、卡頓,現(xiàn)在你一定還不太理解,下面進(jìn)行詳細(xì)講解,需要的朋友可以參考下
    2022-12-12
  • 在react-router4中進(jìn)行代碼拆分的方法(基于webpack)

    在react-router4中進(jìn)行代碼拆分的方法(基于webpack)

    這篇文章主要介紹了在react-router4中進(jìn)行代碼拆分的方法(基于webpack),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-03-03
  • react native 獲取地理位置的方法示例

    react native 獲取地理位置的方法示例

    這篇文章主要介紹了react native 獲取地理位置的方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-08-08
  • 基于React實(shí)現(xiàn)無限滾動(dòng)表格

    基于React實(shí)現(xiàn)無限滾動(dòng)表格

    以文本為例,為了實(shí)現(xiàn)無限循環(huán)的視覺效果,我們需要準(zhǔn)備兩段相同的文本,并讓第二段文本的頭部銜接在第一段文本的尾部,同時(shí),為兩段文本設(shè)置相同的滾動(dòng)動(dòng)畫,本文給大家介紹了基于React實(shí)現(xiàn)無限滾動(dòng)表格,需要的朋友可以參考下
    2023-11-11
  • react腳手架如何配置less和ant按需加載的方法步驟

    react腳手架如何配置less和ant按需加載的方法步驟

    這篇文章主要介紹了react腳手架如何配置less和ant按需加載的方法步驟,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-11-11
  • 使用React手寫一個(gè)對(duì)話框或模態(tài)框的方法示例

    使用React手寫一個(gè)對(duì)話框或模態(tài)框的方法示例

    這篇文章主要介紹了使用React手寫一個(gè)對(duì)話框或模態(tài)框的方法示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 詳解React-Todos入門例子

    詳解React-Todos入門例子

    本篇文章主要介紹了React-Todos入門例子,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-11-11

最新評(píng)論