条件渲染

  React中的条件渲染和我们平常写的js 代码一样,都是用的if else, 只不过在if else 中它的返回值是jsx, 根据不同的条件渲染不同的UI. 先写两个组件

     //登录的用户显示欢迎
      function UserWelcome(){
        return <h1>Welcome to user</h1>
      }
      //为登录的用户显示请登录
      function GusterWelcome(){
        return <h1>please sign up</h1>
      }

  再写一个组件进行条件判断,从而显示不同的组件

function Greeting(props){
        const isLogged  = props.isLogged;

        // 根据条件进行判断,渲染不同的组件。
        if(isLogged){
          return <UserWelcome />  // 返回jsx
        }else {
          return <GusterWelcome/>
        }
      }

  渲染Greeting 组件,给他一个isLogged 参数,控制显示和隐藏, isLogged参数是true  or false, 可以看到页面显示不同的内容

 ReactDOM.render(
    <Greeting isLogged={true} />,
    document.getElementById('root')
 );

  如果是简单的条件渲染,也可以在jsx中使用条件表达式,直接用{} 把表达式包起来,因为在jsx 中,{} 中的内容都可以进行计算。如果只有条件成立的情况下执行的内容,可以使用 && 运算符, 如果条件成立和条件不成立都要执行,那就要用 三目运算符。

  比如我们只想在isLogged 为true的情况下渲染组件,false 则不显示。那么我们就要用&& 。Greeting 组件修改如下

function Greeting(props){
        const isLogged  = props.isLogged;
        return (
          <div>
            {isLogged && <UserWelcome />}
          </div>
        )
      }

  注意,这时要用div 标签把条件表达式包括起来,否则会报错。再用三元运算符对于Greeting 进行修改

function Greeting(props){
        const isLogged  = props.isLogged;
        return (
          <div>
            {isLogged? <UserWelcome />: <GusterWelcome />}
          </div>
        )
      }

  列表渲染

  React 中的列表渲染,用的是数组的map 方法,将数组中的每一项映射成一个jsx, 然后进行返回。数组就是我们要渲染到页面中的数据, 那么经过map 方法之后返回的新数组,每一项都成了包含渲染数据的jsx, 我们再对新数组进行渲染就可以把数据渲染到页面中.

    // 要渲染到页面中的数据
    const numbers = [1, 2, 3, 4, 5]; 
    // listItems 经过map方法返回的新数组,它的每一项都是jsx
    const listItems = numbers.map((number) =>
      <li>{number}</li>
    );
    ReactDOM.render(
      <ul>{listItems}</ul>,  // 对新数组进行渲染,就可以在页面中显示数据
      document.getElementById('root')
    );

  我们这个list 组件封装为一个组件

function NumberList(props) {
  const numbers = props.numbers;
  const listItems = numbers.map((number) =>
    <li>{number}</li>
  );
  return (
    <ul>{listItems}</ul>
  );
}

  列表组件的调用

const numbers = [1, 2, 3, 4, 5];
ReactDOM.render(
  <NumberList numbers={numbers} />,
  document.getElementById('root')
);

  在进行列表渲染的时候,一定要给它一个key,表示每一个列表项都是唯一的,这有利于是react 优化。Key是一个字符串,给li增加一个key

<li key={number.toString()}>
    {number}
  </li>

  由于每一项的key值是独一无二的,所以最好的key 就是每一项上的id, 那么把我们的数组改成每一项都是对象,同时对listItems 进行修改

const numbers = [
      {
        id:"first",
        num: 1
      },
      {
        id: "second",
        num: 2
      }
    ]
 const listItems = numbers.map((number) =>
    <li key={number.id}>{number.num}</li>
  );

  但有的时候每一个li内容都很多,我们需要把 li 单独封装成一个组件

function ListItem(props) {
  const value = props.value;
  return<li>{value}</li>
}

  那这时key怎么处理,key 永远跟随map方法中的函数,只有map 才能产生循环, 只有在循环内确保唯一性。

function NumberList(props) {
  const numbers = props.numbers;
  const listItems = numbers.map((number) =>

    <ListItem key={number.id} value={number.num} />
  );
  return (
    <ul>
      {listItems}
    </ul>
  );
}

  表单操作

  表单是特殊的html 元素,因为它有自己的状态,最典型的就是输入框,用户输入,输入框中直接显示用户输入的内容,它们状态都是自保持的, 这与react 所有状态是放到组件中且只能通过setState改变状态是不相符的。这时react 通过value 和onchange 事件组合解决。表单元素的value 属性从 state 中获取,用户输入时触发onChange 事件,onChange 事件中通过setState() 来动态改变状态,使输入框中的内容实时显示用户输入的内容,input, textarea, select都是这么操作的,这里要注意的是 value 和onChange 事件要写到select 标签中, textarea 也是一样。

class FormSelection extends React.Component {
        constructor(props){
          super(props);
          this.state = {value: 'lime'}   // 设置初始状态,就是下拉列表默认选择的一项
        }

        handleChange = (e) => {
          this.setState({value: e.target.value})  // 改变状态
        }

        render(){
          return (
            <form>
              <label>
                Pick your favorite La Croix flavor:
                <select value={this.state.value} onChange={this.handleChange}>  // value 和onChange 事件写到select标签中
                  <option value="grapefruit">Grapefruit</option>
                  <option value="lime">Lime</option>
                  <option value="coconut">Coconut</option>
                  <option value="mango">Mango</option>
                </select>
              </label>
            </form>
          )
        }
      }

  对于一个组件中有多个input,怎样设置状态? 无论是哪一个input, 只要是一输入,它就会调用onChange 事件,setState 方法,setState 方法第一个参数,就是要设置的属性,第二个参数就是得到的用记输入的值,它不会变化,都是event.target.value.  所以这里的核心就是怎么处理要设置的属性,就是我们怎么确定是哪一个input. 这要给每一个input设置一个标识, 可以用input 的name 属性,并且它的name 属性等于它的状态, 这时用户输入的时候,我们能获取到是哪个input(event.target.name),且name 值正好等于它的状态,我们调用setState() 的时候,直接把获取到的用户的值(event.target.value)  赋值给name,就可以改变input 的状态, 和用户的输入保持同步。

 

   class FormSelection extends React.Component {
        constructor(props){
          super(props);
          this.state = {
            isGoing: true,
            numberOfGuests:2
          }
        }

        handleInputChange = (event) => {
          const target = event.target;
          // 获取用户输入的值
          const value = target.type === 'checkbox'? target.checked: target.value;
          // 通过name 获取到用于点击的输入框,由于name的取值是状态值,同时获取到input 当前状态
          const name = target.name;
          // 用户输入的值赋值给 name, 同时改变了input的状态
          this.setState({[name]: value})
        }

        render(){
          // 对于有两个input,给每一个input name值,唯一标识,且取值为状态值,同时保存当前状态
          return (
            <form>
              <label>
                Is going: <input name='isGoing' type="checkbox" checked= {this.state.isGoing}
                  onChange= {this.handleInputChange} />
              </label>
              <br />
              <label>
                Number of Guests:
                <input name='numberOfGuests' type='number' value={this.state.numberOfGuests}
                  onChange={this.handleInputChange} />
              </label>
            </form>
          )
        }
      }

      ReactDOM.render(
        <FormSelection />,
        document.getElementById('root')
      );

    

React 学习(五) ---- 条件和列表渲染的更多相关文章

  1. Vue学习(五):列表渲染

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. 【vue2】Style和Class,条件,列表渲染,双向数据绑定,事件处理

    目录 1.style和class 2. 条件渲染 2.1 指令 2.2 案例 3. 列表渲染 3.1 v-for:放在标签上,可以循环显示多个此标签 3.2 v-for 循环数组,循环字符串,数字,对 ...

  3. react学习(二)--元素渲染

    元素用来描述你在屏幕上看到的内容: const element = <h1>Hello, world</h1>; 与浏览器的 DOM 元素不同,React 当中的元素事实上是普 ...

  4. react 入坑笔记(五) - 条件渲染和列表渲染

    条件渲染和列表渲染 一.条件渲染 条件渲染较简单,使用 JavaScript 操作符 if 或条件运算符来创建表示当前状态的元素,然后让 React 根据它们来更新 UI. 贴一个小栗子: funct ...

  5. vue学习笔记(五)条件渲染和列表渲染

    前言 在众多的编程语言中,我们的基础语法总是少不了一些专业语法,比如像定义变量,条件语句,for循环,数组,函数等等,vue.js这个优秀的前端框架中也有同样的语法,我们换一个名词,将条件语句改成专业 ...

  6. 前端MVC Vue2学习总结(四)——条件渲染、列表渲染、事件处理器

    一.条件渲染 1.1.v-if 在字符串模板中,如 Handlebars ,我们得像这样写一个条件块: <!-- Handlebars 模板 --> {{#if ok}} <h1&g ...

  7. angular,vue,react的基本语法—双向数据绑定、条件渲染、列表渲染、angular小案例

    基本语法: 1.双向数据绑定 vue 指令:v-model="msg" react constructor(){ this.state{ msg:"双向数据绑定" ...

  8. React学习笔记(七)条件渲染

    React学习笔记(七) 六.条件渲染 使用if或条件运算符来创建表示当前状态的元素. 可以使用变量来存储元素.比如: let button = null; if (isLoggedIn) { but ...

  9. react 也就这么回事 02 —— JSX 插值表达式、条件渲染以及列表渲染

    我们已经学会了 React 创建元素和渲染元素 ReactDOM.render(<div>Hello React!</div>, document.getElementById ...

随机推荐

  1. SkylineGlobe TerraExplorer Pro 遇到模型显示有锯齿怎么办?

    SkylineGlobe TerraExplorer Pro 遇到模型显示有锯齿怎么办? 这个问题跟软件的版本无关,跟机器的显卡有关,看下面的截图: 试试看,祝你好运!

  2. Intellij Idea 2017创建web项目及tomcat部署实战

    相关软件:Intellij Idea2017.jdk16.tomcat7 Intellij Idea直接安装(可根据需要选择自己设置的安装目录),jdk使用1.6/1.7/1.8都可以,主要是配置好系 ...

  3. 调整代码生成工具Database2Sharp的Winform界面生成,使其易于列表工具栏的使用。

    在Winform界面开发的时候,有时候我们客户喜欢把功能放在列表界面的顶部,这样界面和功能整齐放置,也是一种比较美观的方式,基于这种方式的考虑,改造了代码生成工具的Winform界面生成规则,把增删改 ...

  4. Python异常处理try except

    原文地址:https://www.cnblogs.com/init-life/p/9105546.html 异常处理try except 在Python中,异常处理,主要是try except语句,通 ...

  5. 二、截取字符串长度(css方式)

    只针对谷歌 width: 100%; //height: 58px; overflow:hidden; text-overflow:ellipsis; display: -webkit-box; -w ...

  6. CF每日一练 Codeforces Round #520 (Div. 2)

    比赛过程总结:过程中有事就玩手机了,后面打的状态不是很好,A题理解错题意,表明了内心不在状态,B题想法和思路都是完全正确的,但是并没有写出来,因为自己代码能力不强,思路不是特别清晰,把代码后面写乱了, ...

  7. ubuntu中更改apache默认目录的方法

    如上,在这两个文件中,我都改为/home/www 及/home/www/html

  8. 初用Ajax

    早就有学习Ajax的想法了,但每次拿起一本Ajax的书,翻了不到百页就学不下去了,里面讲的东西实在太多了,前面讲javaScript的内容看了好 几遍都记不住,也就没心思去看后面的内容:看Ajax案例 ...

  9. latex 图片标题居中

    1.有一个全局图片标题居中的方法: \usepackage[justification=centering]{caption} 2.如果排版时有的图标题想左对齐,有的想居中,前一个方法就不好了,这里可 ...

  10. git rebase的用法

    改变基 一个git库,开发人员在master分支的Bcommit的时候,创建了一个dev分支,此时Bcommit是dev分支的基,然后分别进行两个分支的开发. 进行到master提交了Dcommit, ...