Reactjs 入门基础(二)

如果我们需要向组件传递参数,可以使用 this.props 对象,实例如下:

  <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="柠檬先生" />,
      document.getElementById(‘example‘)
    );
   </script>
  </body>
  注意,在添加属性时, class 属性需要写成 className ,for 属性需要写成 htmlFor ,这是因为 class 和 for 是 JavaScript 的保留字。

如果我们需要向组件传递参数,可以使用 this.props 对象,实例如下:
  <body>
    <div id="example"></div>
    <script type="text/babel">
      var WebSite = React.createClass({
          render: function() {
            return (
              <div>
                <Name name={this.props.name} />
                <Link site={this.props.site} />
              </div>
            );
        }
      });

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

     var Link = React.createClass({
          render: function() {
            return (
              <a href={this.props.site}>
                {this.props.site}
              </a>
            );
        }
    });

    React.render(
      <WebSite name="柠檬先生" site=" http://www.baidu.com" />,
      document.getElementById(‘example‘)
    );
   </script>
  </body>

React State(状态)

  React 把组件看成是一个状态机(State Machines)。通过与用户的交互,实现不同状态,然后渲染 UI,让用户界面和数据保持一致。
  React 里,只需更新组件的 state,然后根据新的 state 重新渲染用户界面(不要操作 DOM)。
  以下实例中创建了 LikeButton 组件,getInitialState 方法用于定义初始状态,也就是一个对象,这个对象可以通过 this.state 属性读取。
  当用户点击组件,导致状态变化,this.setState 方法就修改状态值,每次修改以后,自动调用 this.render 方法,再次渲染组件。

    <body>
      <div id="example"></div>
      <script type="text/babel">
          var LikeButton = React.createClass({
            getInitialState: function() {
              return {liked: false};
          },
          handleClick: function(event) {
            this.setState({liked: !this.state.liked});
          },
          render: function() {
            var text = this.state.liked ? ‘喜欢‘ : ‘不喜欢‘;
            return (
                <p onClick={this.handleClick}>
                  你<b>{text}</b>我。点我切换状态。
                </p>
              );
          }
        });

        React.render(
          <LikeButton />,
          document.getElementById(‘example‘)
        );
      </script>
    </body>

React Props

  使用 Props
      <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="柠檬先生" />,
              document.getElementById(‘example‘)
          );
      </script>
     </body>

默认 Props
    你可以通过 getDefaultProps() 方法为 props 设置默认值,实例如下:

    <body>
      <div id="example"></div>
      <script type="text/babel">
        var HelloMessage = React.createClass({
            getDefaultProps: function() {
              return {
                  name: ‘柠檬先生‘
                };
            },
            render: function() {
                  return <h1>Hello {this.props.name}</h1>;
            }
        });

        ReactDOM.render(
          <HelloMessage />,
          document.getElementById(‘example‘)
        );
    </script>
  </body>

时间: 2024-11-12 03:41:53

Reactjs 入门基础(二)的相关文章

【LaTeX排版】LaTeX使用--入门基础&lt;二&gt;

1.在命令之后留一个空格有下列方式: 源文件如下: \documentclass[a4paper,12pt]{book}%采用book类型(中篇论文一般采用这种类型),A4纸,字体为12磅,默认为10磅 \usepackage{ctexcap}%采用中文标题宏包(标题是中文的) %\usepackage{ctex}%采用中文字体宏包(标题是英文的)与ctexcap不能同时使用 \begin{document} {\LaTeX} 是一个排版工具 %命令行后保留空格的三种方法 \par %另起一段,

ReactJS入门基础

渲染这俩字可能在很多地方都见过.但可能不太理解是啥意思. 那么首先我们来理解一下渲染. 渲染 我觉得这样理解比较通俗. 我们做一个汽车,开始是没有喷漆的(没有css) 只是些框框架架(HTML标签).那么网页加载就是首先加载完HTML元素,其次是css,css去遍历渲染每个对应元素的样式让其看起来就是我们所想看到的效果一样.不同浏览器的渲染方式不一样,渲染机制也不一样. 简单来将一个完整的HTML页面渲染完成是有2个东西的.一个HTML元素加载完成,一个是CSS样式加载完成.其次才是JS,如果J

mybatis入门基础(二)----原始dao的开发和mapper代理开发

阅读目录 一:原始dao开发方法 二:mapper代理方法(只需要mapper接口,相当于dao接口) 承接上一篇 mybatis入门基础(一) 看过上一篇的朋友,肯定可以看出,里面的MybatisService中存在大量的重复代码,看起来不是很清楚,但第一次那样写,是为了解mybatis的执行步骤,先苦后甜嘛! 回到顶部 一:原始dao开发方法 概要:1.在上篇中搭建好的框价中编写dao接口和dao实现类 2.向dao接口实现类中注入SqlSessionFactory,在方法体内通过SqlSe

C#入门基础二

万物皆对象:对象是包含数据和操作的实体. 属性:名词     /  对象     \      方法:动词 ============================================================================= 类:    类的成员--静态成员属于类,实例成员属于对象(类的实例).使用类声明可以创建新的类.对象所拥有的特征,在类中表示时称为类的属性.类可同等级写也可包含写.    声明类的语法:[访问修饰符]class<类名(自定义)>   

Reactjs 入门基础(三)

State 和 Props以下实例演示了如何在应用中组合使用 state 和 props .我们可以在父组件中设置 state, 并通过在子组件上使用 props 将其传递到子组件上.在 render 函数中, 我们设置 name 和 site 来获取父组件传递过来的数据. Props 验证 Props 验证使用 propTypes,它可以保证我们的应用组件被正确使用,React.PropTypes 提供很多验证器 (validator) 来验证传入数据是否有效.当向 props 传入无效数据时

2015.4.8-C#入门基础(二)

初来乍道,下面分享一下,自己做的小程序 主要用到 数组,类型转换,枚举,循环: 主要体现的是: 输入姓名,就可以查看其性格 using System;using System.Collections.Generic;using System.Linq;using System.Text;namespace ConsoleApplication11 { class Program {          public enum name{马森,穆安峰,曹真,崔雄,张梦婷,杨明珠};         

ReactJS入门二

ReactJS入门学习二 ReactJS入门学习二 阅读目录 React的背景和基本原理 理解React.render() 什么是JSX? 为什么要使用JSX? JSX的语法 如何在JSX中如何使用事件 如何在JSX中如何使用样式 回到顶部 React的背景和基本原理 在web开发中,我们总需要将变化的数据实时反应到UI上,这时就需要对DOM进行操作,复杂或频繁的对DOM操作是性能瓶颈产生的原因,React为此引入了虚拟的DOM的机制,在浏览器端使用javascript实现了一套DOM API,

PHP基础入门(二)---入门必备哦!

前言 在上一章中,我们初步了解了PHP的网页基础和PHP的入门基础,今天继续给大家分享更多有关PHP的知识. 理论知识看起来可能比较枯燥一些,但是我们的实践(敲代码)毕竟离不开它. 只有理论与实践相结合,才可以用最少的代码实现更多的功能. ***本章关键字:运算符:可变变量:取址符号:分支与循环:流程控制语句goto. 下面,我们来看了解一下PHP中的运算符及更多PHP知识基础: 一运算符 1.算术运算符:+ - * / % ++ -- 2.赋值运算符:= += -= *= /= %= .=(连

PHP基础入门(二)【PHP函数基础】

PHP基础入门(二)--函数基础 了解 PHP基础入门详解(一) 后,给大家分享一下PHP的函数基础. 这部分主要讲的就是: 函数的声明与使用.PHP中变量的作用域.静态变量.函数的参数传递.变量函数.回调函数.匿名函数.include&require.PHP闭包 PHP的函数基础↓↓↓ 一.函数的声明与使用 1.标识符:程序中的变量名,属性名,方法名,函数名,类名统称为标识符: ① 标识符的命名要求:  只要是标识符,命名就只有字母.数字.下划线组成,开头不能是数字: ② 标识符的命名规范: