react.JS基础

1、ReactDOM.render()

  React.render 是 React 的最基本方法,用于将模板转为 HTML 语言,并插入指定的 DOM 节点。

 1 <!DOCTYPE html>
 2 <html>
 3     <head>
 4         <meta charset="utf-8" />
 5         <title></title>
 6         <script type="text/javascript" src="js/react.js"></script>
 7         <script type="text/javascript" src="js/react-dom.js"></script>
 8         <script type="text/javascript" src="js/browser.min.js"></script>
 9         <style type="text/css">
10             #example{width: 300px;height: 100px;background: lightblue;}
11         </style>
12     </head>
13     <body>
14         <div id="example"></div>
16         <script type="text/babel">
17             ReactDOM.render(
18             <p>测试reactdom.render</p>,
19             document.getElementById("example")
20             )
21         </script>
22     </body>
23 </html>
运行结果:



 2、jsx语法

  HTML 语言直接写在 JavaScript 语言之中,不加任何引号,这就是 JSX 的语法,它允许 HTML 与 JavaScript 的混写。

 1 <!DOCTYPE html>
 2 <html>
 3     <head>
 4         <meta charset="utf-8" />
 5         <title></title>
 6         <script type="text/javascript" src="js/react.js"></script>
 7         <script type="text/javascript" src="js/react-dom.js"></script>
 8         <script type="text/javascript" src="js/browser.min.js"></script>
 9         <style type="text/css">
10             #example{width: auto;height: 100px;background: lightblue;}
11         </style>
12     </head>
13     <body>
14         <div id="example"></div>
15         <script type="text/babel">
16             var names=[‘AAA‘,‘BBB‘,‘CCC‘];
17             ReactDOM.render(
18             <div>
19                 {
20                     names.map(function(name,index){
21                         return <div key={index}>Hello,{name}!</div>
22                     })
23                 }
24             </div>,
25             document.getElementById("example")
26             )
27         </script>
28     </body>
29 </html>

运行结果:

  • 上面代码体现了 JSX 的基本语法规则:遇到 HTML 标签(以 < 开头),就用 HTML 规则解析;遇到代码块(以 { 开头),就用 JavaScript 规则解析。
  • JSX 允许直接在模板插入 JavaScript 变量。如果这个变量是一个数组,则会展开这个数组的所有成员。
<body>
        <div id="example"></div>
        <script type="text/babel">
            var arr=[
                <h1 key="1">Hello world!</h1>,
                <h2 key="2">I love react!</h2>,
            ];
            ReactDOM.render(
            <div>{arr}</div>,
            document.getElementById("example")
            )
        </script>
</body>

运行结果:



3、组件

  React 允许将代码封装成组件(component),然后像插入普通 HTML 标签一样,在网页中插入这个组件。React.createClass 方法就用于生成一个组件类。

 1 <body>
 2         <div id="example"></div>
 3         <script type="text/babel">
 4             var HelloMessage = React.createClass({
 5                 render:function(){
 6                     return <h1>Hello {this.props.name}</h1>
 7                 }
 8             });
 9             ReactDOM.render(
10             <HelloMessage name = "John" />,
11             document.getElementById("example")
12             )
13         </script>
14 </body>

运行结果:

  上面代码中,变量 HelloMessage 就是一个组件类。模板插入 <HelloMessage /> 时,会自动生成 HelloMessage 的一个实例(下文的‘组件‘都指组件类的实例)。所有组件类都必须有自己的 render 方法,用于输出组件。

  组件的用法与原生的 HTML 标签完全一致,可以任意加入属性,比如 <HelloMessage name=‘John‘ /> ,就是 HelloMessage 组件加入一个 name 属性,值为 John。组件的属性可以在组件类的 this.props 对象上获取,比如 name 属性就可以通过 this.props.name 读取。


4、this.props.children

  this.props.children 属性,它表示组件的所有子节点。

 1 <body>
 2         <div id="example"></div>
 3         <script type="text/babel">
 4             var NotesList = React.createClass({
 5                 render: function() {
 6                     return(
 7                     <ol>
 8                         {
 9                             React.Children.map(this.props.children,function(child){
10                                 return <li>{child}</li>;
11                             })
12                         }
13                     </ol>
14                     );
15                 }
16             });
17             ReactDOM.render(
18             <NotesList>
19                 <span>hello</span>
20                 <span>world</span>
21             </NotesList>,
22             document.getElementById("example")
23             );
24         </script>
25  </body>

运行结果: 


 5、React.findDOMNode()

  组件并不是真实的 DOM 节点,而是存在于内存之中的一种数据结构,叫做虚拟 DOM (virtual DOM)。只有当它插入文档以后,才会变成真实的 DOM 。根据 React 的设计,所有的 DOM 变动,都先在虚拟 DOM 上发生,然后再将实际发生变动的部分,反映在真实 DOM上,这种算法叫做 DOM diff ,它可以极大提高网页的性能表现。但是,有时需要从组件获取真实 DOM 的节点,这时就要用到 React.findDOMNode 方法。

 1 <body>
 2         <div id="example"></div>
 3         <script type="text/babel">
 4             var MyComponent = React.createClass({
 5                 handleClick:function(){
 6                     this.refs.myTextInput.focus();
 7                 },
 8                 render:function(){
 9                     return(
10                     <div>
11                         <input type="text" ref="myTextInput" />
12                         <input type="button" value="Focus the text input" onclick={this.handleClick} />
13                     </div>
14                     );
15                 }
16             });
17
18             ReactDOM.render(
19             <MyComponent/>,
20             document.getElementById(‘example‘)
21             )
22         </script>
23     </body>运行结果:
 1 <body>
 2         <div id="example"></div>
 3         <script type="text/babel">
 4             var data = 123;
 5             var MyTitle = React.createClass({
 6                 propTypes: {
 7                   title: React.PropTypes.string.isRequired,
 8                 },
 9                 render: function() {
10                   return <h1> {this.props.title} </h1>;
11                 }
12              });
13             ReactDOM.render(
14                 <MyTitle title={data} />,
15                 document.getElementById(‘example‘)
16               );
17         </script>
18     </body>  运行结果:  


 6、this.state

  组件免不了要与用户互动,React 的一大创新,就是将组件看成是一个状态机,一开始有一个初始状态,然后用户互动,导致状态变化,从而触发重新渲染 UI。

 1     <body>
 2         <div id="example"></div>
 3         <script type="text/babel">
 4             var LikeButton = React.createClass({
 5             getInitialState: function() {
 6                 return {liked: false};
 7             },
 8             handleClick: function(event) {
 9                 this.setState({liked: !this.state.liked});
10             },
11               render: function() {
12                 var text = this.state.liked ? ‘like‘ : ‘haven\‘t liked‘;
13                 return (
14                   <p onClick={this.handleClick}>
15                     You {text} this. Click to toggle.
16                   </p>
17                 );
18               }
19             });
20             ReactDOM.render(
21               <LikeButton />,
22               document.getElementById(‘example‘)
23             );
24         </script>
25     </body>

  上面代码是一个 LikeButton 组件,它的 getInitialState 方法用于定义初始状态,也就是一个对象,这个对象可以通过 this.state 属性读取。当用户点击组件,导致状态变化,this.setState 方法就修改状态值,每次修改以后,自动调用 this.render 方法,再次渲染组件。

  由于 this.props 和 this.state 都用于描述组件的特性,可能会产生混淆。一个简单的区分方法是,this.props 表示那些一旦定义,就不再改变的特性,而 this.state 是会随着用户互动而产生变化的特性。



7、表单

 1 <body>
 2         <div id="example"></div>
 3         <script type="text/babel">
 4             var Input = React.createClass({ getInitialState: function() { return {value: ‘Hello!‘}; }, handleChange: function(event) { this.setState({value: event.target.value}); }, render: function () { var value = this.state.value; return (
 5             <div>
 6                 <input type="text" value={value} onChange={this.handleChange} />
 7                 <p>{value}</p>
 8             </div>
 9             ); } }); ReactDOM.render(
10             <Input/>, document.getElementById(‘example‘));
11         </script>
12     </body>
时间: 2024-10-11 17:07:56

react.JS基础的相关文章

React JS 基础知识17条

1. 基础实例 <!DOCTYPE html> <html> <head> <script src="../build/react.js"></script> <script src="../build/react-dom.js"></script> <script src="../build/browser.min.js"></script&g

React.js 基础入门三 ---组件状态state

React 组件实例在渲染的时候创建.这些实例在接下来的渲染中被重复使用,可以在组件方法中通过 this 访问.唯一一种在 React 之外获取 React 组件实例句柄的方式就是保存React.render 的返回值.在其它组件内,可以使用 refs 得到相同的结果(后面会简单解释refs). 从上几章的学习,我们可以这么理解组件,学过php的Yii框架的都知道widget组件,react.js定义一个组件,通过在组件中定义各种'方法','属性'最后通过render来渲染这个组件. 其中<组建

React.js 基础入门四--要点总结

JSX语法,像是在Javascript代码里直接写XML的语法,实质上这只是一个语法糖,每一个XML标签都会被JSX转换工具转换成纯Javascript代码,React 官方推荐使用JSX, 当然你想直接使用纯Javascript代码写也是可以的,只是使用JSX,组件的结构和组件之间的关系看上去更加清晰. 1. HTML 标签 和 React 组件 在JS中写HTML标签,也许小伙伴们都惊呆了,那么React又是怎么区分HTML标签,React组件标签? HTML标签: var myDivEle

React.js 基础入门二--组件嵌套

组件:在设计接口的时候,将常用元素(按钮,表单字段,布局组件等)分解成定义好接口的可重用组件.这样下次你在创建同样界面就可以少写很多代码,这意味着更快的开发时间,更少的bug,和更少的内容下载. 将上章节Index.html中Js部分修改为: <script type="text/jsx">   // 注意此处                 // 定义web组件 (<font color="#ff0000">MessageBox 错误组件嵌

React.js入门基础一

React A JAVASCRIPT LIBRARY FOR BUILDING USER INTERFACES 下面是为什么在你选择之前需要再考虑一下:(摘录) 一开始 React 会极大地减慢你的开发.理解props.state以及组件通信如何工作并不是很简单,并且文档信息错综复杂.理论上,这将会被克服,你的整个团队都上道之后,开发速度上就会有一个很大的提升. React 不支持 IE8 以下的任何浏览器,以后也绝不会. 如果你的应用/站点不需要频繁的动态页面更新,你可能为了很小的功能而编写大

结合基础与实战学习React.js 独立开发新闻头条平台

第1章 课程简介课程导读,介绍了课程的基本结构.课程的特点.最终实战项目演示.前置知识点以及源码打包结构和后期相关学习资料的更新方式. 第2章 React 简介对 React 进行了详细地简介并对课程的前置知识点进行了详细地梳理. 第3章 React 初体验介绍了此课程中使用的 React 版本以及官网学习包 React Starter Pack 的下载与安装,并对 React 的框架运行进行了初体验. 第4章 NodeJS简介与安装对 NodeJS 进行了详细地介绍,并完整演示了 NodeJS

Angular、React.js 和Node.js到底选谁?

为了工作,程序员选择正确的框架和库来构建应用程序是至关重要的,这也就是为什么Angular和React之间有着太多的争议.Node.js的出现,让这场战争变得更加复杂,虽然有选择权通常是一件很棒的事情,但在这种情况下,对于到底应该选择哪种框架,程序员之间并没有一致的意见,每个人都有不同的想法,并且听起来都相当合理. 为了让一切归于和谐,本文就来探究一下这三大框架各自的优缺点. 基础知识部分: 在我们深入研究这三种框架的具体细节之前,先来了解一些前情提要.yigouyul22.com xucaiz

Flux --&gt; Redux --&gt; Redux React 入门 基础实例使用

本文的目的很简单,介绍Redux相关概念用法 及其在React项目中的基本使用 假设你会一些ES6.会一些React.有看过Redux相关的文章,这篇入门小文应该能帮助你理一下相关的知识 一般来说,推荐使用 ES6+React+Webpack 的开发模式,但Webpack需要配置一些东西,你可以先略过,本文不需要Webpack基础 入门,只是一些基础概念和用法的整理,更完整的内容推荐去看看文档,英文,中文 (不过我个人认为,官方文档的例子相对来说太复杂了,很难让新手马上抓住重点) (官方的例子正

10 个打造 React.js App 的最佳 UI 框架

在本文中,我们将分享一些助你打造 React.js App 最佳的 UI 框架.它们具备你所需要的基本 React 组件,以及易用的 API,同时,在外观和体验上也非常棒.Have Fun ! 1. Material-UI 基于谷歌 Material Design 设计规范的 React 组件 此外,它还是 React 的第一个 UI 套件.Material-UI具备你所需要的所有组件(甚至更多),以及可配置性极高的预定义调色板和<MuiThemeProvider>,帮助你为应用程序定制相应的