React--組件

来源:https://www.cnblogs.com/n2meetu/archive/2018/04/12/8805207.html
-Advertisement-
Play Games

註意 /`會報錯 React的props React中的每一個組件,都包含有一個屬性(props),在組件內部,我們可以通過this.props獲取屬性對象。 組件如下: 屬性使用方法: 1.直接調key/value 2.延展屬性 用{...props}方法 3.調用組件的setProps函數來指定 ...


<!DOCTYPE html>
<!-- React 允許將代碼封裝成組件(component),
然後像插入普通 HTML 標簽一樣,在網頁中插入這個組件。 -->
<html>
<head>
    <script src="./js/react.js"></script>
    <script src="./js/react-dom.js"></script>
    <script src="./js/browser.min.js"></script>
</head>
<body>
    <div id="example"></div>
    <script type="text/babel">
        var HelloMessage = React.createClass({
            render:function () {
                return <h1>hello {this.props.name}</h1>
            }
        })

        ReactDOM.render(
           <HelloMessage name="Helen" />,  
           document.getElementById('example') 
        );
    </script>
</body>

</html>
註意

<HelloMessage name="Helen" />是個半閉合標簽,少/會報錯

React的props

React中的每一個組件,都包含有一個屬性(props),在組件內部,我們可以通過this.props獲取屬性對象。

組件如下:

React.render(  
    <HelloWorld name="Jack"/>,  //name屬性的值是“jack”
    document.getElementById('container')  
); 

屬性使用方法:

1.直接調key/value

var HelloWorld = React.createClass({  
    render:function(){
        return {
            <div> hello{this.props.name} </div>
        }
    }
}); 

2.延展屬性

用{...props}方法
<div id="example"></div>
    <script type="text/babel">
    // 創建組件  React.createClass
        var HelloMessage = React.createClass({
            render:function () {
                return <h1>hello {this.props.name1},{this.props.name2}</h1>
            }
        })

        var props = {
            name1:"andy",
            name2:"tom"
        }

        ReactDOM.render(
           <HelloMessage {...props}/>,
           document.getElementById('example') 
        );
        
    </script>

3.調用組件的setProps函數來指定屬性

    <div id="example"></div>
    <script type="text/babel">
        var HelloMessage = React.createClass({
            render:function () {
                return <h1>hello {this.props.name}</h1>
            }
        })

        var instance  = React.render(  // 為什麼不是ReactDOM.render??
            <hello />,
            document.getElementById('example');
        )
        
        instance.setProps({name:'jack'});
        
    </script>

自己設置了組件的屬性值。

但是不建議用這種方式修改屬性值,因為React沒有辦法幫你檢查屬性的類型(propTypes)。如果用在工程中,這麼輕易改掉又沒檢查監督,很容易出問題。所以不要輕易修改。

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

-Advertisement-
Play Games
更多相關文章
  • js 列印 大家好,有陣子沒有寫過博客了,這次在寫項目的過程中遇到了印表機的需求,因為之前寫js是沒有對印表機有更深的瞭解,所以在寫項目的過程中根據需求的不同也遇到了坑。 首先 對於列印由於我之前沒有接觸到所以一開始我去jq22這個網站上找到了一個插件,本以為使用插件的時候可以順理成章的完成這個需求 ...
  • 項目中未讀消息列表,點擊讀取再返回後,仍然顯示未讀。 onpageshow 事件在用戶瀏覽網頁時觸發。 onpageshow 事件類似於 onload 事件,onload 事件在頁面第一次載入時觸發, onpageshow 事件在每次載入頁面時觸發,即 onload 事件在頁面從瀏覽器緩存中讀取時不 ...
  • function a() { var arr = new Array(1000000); for(var i = 0; i < arr.length;i ++) { arr[i] = i; } var start1 = new Date().getTime(); for(var i = 0; i < ...
  • 原生js封裝ajax ...
  • js ajax post 提交的時候後臺接收不到參數,但是代碼沒有錯,怎麼回事 ...
  • Visual Studio不論是2013版本還是2015版本要自動編譯都需要添加擴展。 添加擴展的方法,路徑“工具”->“擴展和更新”,在打開的視窗“搜索”你需要的擴展根據提示“下載”和“安裝”。 首先,來看一下vs2013的擴展:Web Essentials 你不想被編譯的scss文檔在文件名的前 ...
  • [1]避免重覆渲染 [2]避免突變 [3]immutable ...
  • 官網上描述的很詳細,並且開源,輕量。 有興趣的可以去嘗試官網上的demo寫的也很好,並且每個參數也解釋的很詳細。 http://zhoushengfe.com/iosselect/website/index.html#user-content-demos 效果圖: ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...