從0開始學習react(三)

来源:http://www.cnblogs.com/bbbiu/archive/2016/05/06/5459340.html
-Advertisement-
Play Games

這次我們來講解第三節知識,考慮了下,先不去講什麼理論了,畢竟網上一搜一大堆,而且理論真心看不太懂啊!!! 今天我們就直接上實例嘍! 大家HIGH起來!!!(想了好久,還是沒捨得刪這句話) 1.根據下圖配置自己的文件 2.我們先用原始方法 額,忘記告訴大家做什麼項目了,那就在這補上吧,咱們先做一個小D ...


這次我們來講解第三節知識,考慮了下,先不去講什麼理論了,畢竟網上一搜一大堆,而且理論真心看不太懂啊!!!

今天我們就直接上實例嘍!

大家HIGH起來!!!(想了好久,還是沒捨得刪這句話)

 

1.根據下圖配置自己的文件

 

2.我們先用原始方法

額,忘記告訴大家做什麼項目了,那就在這補上吧,咱們先做一個小Demo,既然react是FB的,那我們就做個評論框好了。

 

搭建一個跟這個頁面一樣的模型,當然你要做的更好看,就按你的來吧!

 

我們考慮一下,要是按照原始的方法來怎麼寫?

var container = document.querySelector(".container");
        var mytext =  document.querySelector("textarea");
        var btn = document.querySelector(".btn");
        var Thtml;
        btn.onclick = function(){
      Thtml = mytext.value;
var newNode = document.createElement("p");
newNode.innerHTML = Thtml;
container.appendChild(newNode);
mytext.value = '';
};

寫完後應該是這樣的:

在下麵的輸入框輸入,點擊POST,則上面的div中就添加一條(至於樣式就不要糾結了哈)

3.React方法

我們使用react來達到同樣的效果。

var TweetBox = React.createClass({
        render: function() {
            return (
                <div className="main">
                    <div className="container"></div>
                    <div>
<textarea></textarea>
<input type="button" className="btn" value="Post"/>
           </div>
                </div>
            );
        }
    });
    React.render(
    <TweetBox />,
    document.body
    );

這裡要註意兩點:

1. 很多文檔都是從內部引用的,這裡專門從外部引用,在引用時一定要在<script>標簽里註明類型

 

2.React中元素的class需要寫成className

 

3.請規範你的代碼輸入(這句話有點裝13了),單標記標簽後面一定要拿" / "封閉,別怪我沒給顏色標註啊!

 

同樣的,我們獲得了與用html代碼輸入一樣的內容:

接下來我們來編寫功能,這裡大家最好先去react官網將所有api看一遍,這樣看下麵的內容能更快的瞭解。

4.React編寫詳解

我個人理解的就是react是將所有大的東西細分成小的組件,然後再拼接起來(六神合體雷神王,嗚嗚嗚嗚嗚...) 

我們來簡單分析一下,這個功能大約能分成幾部分。

應該是這樣三部分是吧...

所以我們在編寫時,也應該分為三部分,所以我們的示例代碼應該變成這樣:

其實這裡的Listdiv就相當於

<div class="container"></div>

 

而Editdiv就是

<div>
    <textarea></textarea>
    <input type="button" class="btn" value="Post">
</div>

 

同樣的他們被class名為main的div包裹。

下麵我們就來編寫裡面的組件,不過在那之前我們先將當前初始狀態處理一下:

好的,雖然有註釋,但我們還是逐行翻譯一下:

getInitialState,用於定義初始狀態,也就是一個對象,這個對象可以通過 this.state 屬性讀取,也就是我們例子中的this.state.data(todo),todo是自己命名的一個存儲名,大家自己隨便取啊(避開關鍵字)

handleChange(這個名字也是自己隨便取的),這個方法是用來跟蹤數據的變化,將這個方法綁定到onChange(名字隨便取)里

我們開始定義子組件吧:
  Editdiv:

這裡我們看到了主要的方法handleAdd,我們就來分析一下:

preventDefault,阻止元素髮生預設的行為

ref,React用來獲取dom元素而添加的一個屬性,給你需要獲取的元素上面添加這個屬性,通過ref的值來獲取到這個元素,使用this.refs.xxx.getDOMNode方法

這裡我們將取到的元素(textarea)的值放入newthing中

rows,獲取到輸入的值,這裡用到了props方法(網上有很多關於props和state方法的用法,大家去看看,這個真的很重要,這裡在講解這個的話篇幅就太長了,需要的話,大家可以留言,我會專門抽出一個專題的)

在下麵就是給input中添加onClick(駝峰式寫法)方法,觸發的函數就是我們剛編寫的handleAdd

  Listdiv:

這個組件就簡單的多了,創建class名為container的div,再在裡面添加一個遍歷map方法,返回一個被P元素包裹的值

OK,這裡我們就大功告成了,下麵貼下全部代碼:

var TweetBox = React.createClass({
    // 初始化數據,data的數據由state來控制
    getInitialState: function() {
        return {
            data: []
        };
    },
    // 接收一個傳入的數據,並將它實時更新到組件的 state 中,以便組件根據數據重新render
    // 只要改變了 state ,react自動執行 render 計算
    handleChange: function (rows) {
        this.setState({
            data: rows
        });
    },
    render: function() {
        return (
            <div className="main">
                {
                    /*展示框*/
                }
                <Listdiv todo={this.state.data}/>
                {
                    /*輸入框與提交按鈕*/
                }
                
                <Editdiv onAdd={this.handleChange} todo={this.state.data}/>                
            </div>
        );
    }
});
// 輸入框與提交按鈕
var Editdiv = React.createClass({
    handleAdd: function (e) {
        e.preventDefault();
        // 通過 refs 獲取dom元素,然後獲取輸入的內容
        var inputDom = this.refs.inputnew.getDOMNode();
        var newthing = inputDom.value.trim();
        // 獲取傳入的TweetBox數據
        var rows = this.props.todo;
        if (newthing !== '') {
            // 更新數據,並使用 onAdd 更新到 TweetBox 組件的 state 中
            rows.push(newthing);
            this.props.onAdd(rows);
        }
        inputDom.value = '';
    },
    render: function(){
        return (
            <div>
                <textarea ref="inputnew"></textarea>
                <input type="button" className="btn" onClick={this.handleAdd} id="todo-new" value="Post"/>
            </div>
        )
    }
});
// Listdiv 組件用於展示列表
var Listdiv = React.createClass({
    render: function(){
        return (
            <div className="container">
            {
                this.props.todo.map(function (item) {
                    return (
                        <p>{item}</p>
                    );
                }) 
            }
            </div>
        )
    }
});
React.render(
    <TweetBox />,
    document.body
);

 

 

 

現在真心是越來越難,可能更新就慢了。以前光看別人寫的,自己寫了才發現整理一篇文章真的不容易啊!!!

 

結尾名言:我們都會變,樣子不變,心也會變,許許多多舊友,早已變得如陌生人一般,皆因他們有不同的角色要扮演,去適應生活與環境所需,不得不變。

 

參考資料: React官網 

      React.js的介紹-針對瞭解jQuery的工程師 (很好的文章,如果你對jquery比較瞭解,那麼從這裡去瞭解react會讓你更加容易)

 

  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 基本語法: 區分大小寫: ECMAScript 中的一切(變數,函數名和操作符)都區分大小寫。 標識符: 表示符就是指,變數,函數,屬性名字,或者函數的參數。 1.第一個字元必須是一個字母,下劃線(_)或美元符號($). 2.其他字元可以是字母,下劃線(_),美元符或數字。 註意:格式為,匈牙利命名 ...
  • Jquery中重置表單的錯誤姿勢 $('#yigeform').reset() 正確姿勢 $('#yigeform')[0].reset() ...
  • 摘要 在各種BS架構的應用程式中,往往都希望服務端能夠主動地向客戶端推送各種消息,以達到類似於郵件、消息、待辦事項等通知。 往BS架構本身存在的問題就是,伺服器一直採用的是一問一答的機制。這就意味著如果客戶端不主動地向伺服器發送消息,伺服器就無法得知如何給客戶端推送消息。 隨著HTML、瀏覽器等各項 ...
  • DIV+CSS 清除浮動是頁面佈局中常見的問題,相信各位高手也都有自己的方法,今天在這裡對常見的幾種方法進行總結(PS:談不上是原創,這裡是我自己做的歸納總結,也是我自己內化的過程),希望對您能夠有所幫助。感謝博客園平臺! 來自<一隻有夢想的前端小白> DIV+CSS 浮動效果是指,父元素在未定義高 ...
  • 在js中有幾種模式可以創建對象,通過對象操作所包含的屬性與方法。 一般來說,構造函數名稱的第一個字母為大寫字母,非構造函數名稱的第一個字母為小寫字母,當然,構造函數與一般函數唯一的區別隻是調用的方式不同而已,所以任何函數只要通過new來調用,那它就可以作為構造函數,若不通過new來調用,則與一般函數 ...
  • 效果: ...
  • 本例子實現彈窗的效果: 1、jquery.show.js "); title=$(" "); content=$(" "); showdiv.html(""); showdiv.append(close); showdiv.append(title); showdiv.append(content) ...
  • 全部學習資源下載:http://pan.baidu.com/s/1eSGy3Qi 效果預覽:http://wjf444128852.github.io/demo/baiduditu/index.html html5里完全支持百度地圖 使用步驟 1、 引入百度地圖的JS * 鏈接 - http://a ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...