zoukankan      html  css  js  c++  java
  • 005-JSX简介以及使用

    一、概述

    考虑这个变量声明:  

    const element = <h1>Hello, world!</h1>;

    标签语法既不是字符串也不是HTML。

    它被称为JSX,它是JavaScript的语法扩展。我们建议在React中使用它来描述UI的外观。JSX是一种模板语言,但它具有JavaScript的全部功能。

    JSX生成React“elements”

    1.1、为什么选择JSX

    React拥抱渲染逻辑与其他UI逻辑固有耦合的事实:事件如何处理,状态如何随时间变化以及数据如何准备显示。

    通过将标记和逻辑放入单独的文件中,React不再人为地分离技术,而是将问题与称为“组件”的松散耦合单元分隔开来。

    React不需要使用JSX,但是大多数人在使用JavaScript代码内的UI时发现它有助于视觉辅助。它还允许React显示更多有用的错误和警告消息。

    1.2、在JSX中嵌入表达式

    您可以通过将其包含在大括号中来嵌入JSX中的任何JavaScript表达式。

    例如,2 + 2,user.firstName和formatName(user)都是有效的表达式:

    function formatName(user) {
      return user.firstName + ' ' + user.lastName;
    }
    
    const user = {
      firstName: 'Harper',
      lastName: 'Perez'
    };
    
    const element = (
      <h1>
        Hello, {formatName(user)}!
      </h1>
    );
    
    ReactDOM.render(
      element,
      document.getElementById('root')
    );
     为了便于阅读,可以将JSX分成多行。建议将其包装在括号内以避免自动分号插入的缺陷。

    1.3、JSX也是一个表达式

      编译之后,JSX表达式变成常规的JavaScript函数调用并评估为JavaScript对象。

      这意味着您可以在if语句和for循环中使用JSX,将其分配给变量,将其作为参数接受,并从函数中返回:

    function getGreeting(user) {
      if (user) {
        return <h1>Hello, {formatName(user)}!</h1>;
      }
      return <h1>Hello, Stranger.</h1>;
    }

    1.4、使用JSX指定属性

      可以使用引号将字符串文字指定为属性:

    const element = <div tabIndex="0"></div>;

      您也可以使用大括号将JavaScript表达式嵌入属性中:

    const element = <img src={user.avatarUrl}></img>;

      注:在属性中嵌入JavaScript表达式时,请勿将大括号括起来。您应该使用引号(用于字符串值)或大括号(用于表达式),但不能同时使用同一个属性。

      警告:由于JSX比HTML更接近JavaScript,因此React DOM使用camelCase属性命名约定而不是HTML属性名称。例如,类在JSX中变为className,并且tabindex变为tabIndex。

    1.5、JSX能够包含子标签

    如果标签为空,则可以使用/>立即关闭它,如XML:

    const element = <img src={user.avatarUrl} />;

    包含子节点

    const element = (
      <div>
        <h1>Hello!</h1>
        <h2>Good to see you here.</h2>
      </div>
    );

    1.6、JSX防止注入攻击

    嵌入输入是安全的

    const title = response.potentiallyMaliciousInput;
    // This is safe:
    const element = <h1>{title}</h1>;

    默认情况下,React DOM在渲染之前转义嵌入在JSX中的任何值。因此它确保您永远不会注入任何未明确写入应用程序的内容。在呈现之前,所有内容都会转换为字符串。这有助于防止XSS(跨站点脚本)攻击。

    1.7、JSX表示对象

    Babel将JSX编译为React.createElement()调用。

    这两个例子是相同的:

    const element = (
      <h1 className="greeting">
        Hello, world!
      </h1>
    );
    const element = React.createElement(
      'h1',
      {className: 'greeting'},
      'Hello, world!'
    );

    React.createElement()会执行一些检查来帮助您编写无错代码,但本质上它会创建一个如下所示的对象:

    // Note: this structure is simplified
    const element = {
      type: 'h1',
      props: {
        className: 'greeting',
        children: 'Hello, world!'
      }
    };

    这些对象被称为“React元素”。你可以把它们想象成你想要在屏幕上看到的东西的描述。 React读取这些对象并使用它们来构建DOM并使其保持最新状态。

    建议使用您所选择的编辑器的“Babel”语言定义,以便正确突出显示ES6和JSX代码。

  • 相关阅读:
    linux grep --我最喜欢的命令~~
    svmrank 的误差惩罚因子c选择 经验
    转:机器学习中的算法(2)-支持向量机(SVM)基础
    转:关于python文件操作大全
    python 求两个时间差
    多个excel合并(excel2007)
    oracle12c 新建表空间
    数据库表被锁了
    join ,left join ,right join有什么区别
    最简洁的权限(菜单)控制
  • 原文地址:https://www.cnblogs.com/bjlhx/p/8979914.html
Copyright © 2011-2022 走看看