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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...