React项目使用ES6解决方案及JSX使用示例详解

目录
  • 不使用 ES6
  • 绑定
  • JSX如何?

不使用 ES6

然而,在纯浏览器端使用ES6语法时,浏览器支持存在差异,这需要特殊处理才能正常运行。 支持ES2015桌面浏览器 Chrome:从51版开始,它可以支持ES6 97%的新功能。 Firefox:53版本支持97%的ES6新功能。 Safari:从版本10开始,ES6 99%的新功能都可以得到支持。 IE:Edge 15可以支持96%的ES6新功能。 Edge 14可以支持93%的新ES6功能。(IE7~11基本不支持ES6)

class Greeting extends React.Component {
  render() {
    return <h1>Hello, {this.props.name}</h1>;
  }
}
var createReactClass = require('create-react-class');
var Greeting = createReactClass({
  render: function() {
    return <h1>Hello, {this.props.name}</h1>;
  }
});

绑定

对于使用ES6类关键字创建的React组件,组件中的方法遵循与常规ES6类相同的语法规则。这意味着这些方法不会自动将其绑定到此组件实例。需要显式调用。在构造函数中绑定(this):

class SayHello extends React.Component {
  constructor(props) {
    super(props);
    this.state = {message: 'Hello!'};
    // 这一行很重要!
    this.handleClick = this.handleClick.bind(this);
  }
  handleClick() {
    alert(this.state.message);
  }
  render() {
    // 由于 `this.handleClick` 已经绑定至实例,因此我们才可以用它来处理点击事件
    return (
      <button onClick={this.handleClick}>
        Say hello
      </button>
    );
  }
}

这意味着,如果使用ES6类关键字创建组件,则在处理事件回调时需要编写更多代码。但对于大型项目,这可以提高运营效率。 如果你认为上面的编写方法很乏味,你可以尝试使用Babel插件类属性,它仍然处于实验阶段。

class SayHello extends React.Component {
  constructor(props) {
    super(props);
    this.state = {message: 'Hello!'};
  }
  // 警告:这种语法还处于试验性阶段!
  // 在这里使用箭头函数就可以把方法绑定给实例:
  handleClick = () => {
    alert(this.state.message);
  }
  render() {
    return (
      <button onClick={this.handleClick}>
        Say hello
      </button>
    );
  }
}

请注意,上述语法仍处于实验阶段,这意味着语法可能随时发生变化,最终可能不会包含在框架标准中。 为了安全起见,可以采用以下三种方法: 在构造函数中绑定方法。 使用箭头函数,例如onClick={(e)=>this.handleClick(e)}。 继续使用createReactClass。

var SetIntervalMixin = {
  componentWillMount: function() {
    this.intervals = [];
  },
  setInterval: function() {
    this.intervals.push(setInterval.apply(null, arguments));
  },
  componentWillUnmount: function() {
    this.intervals.forEach(clearInterval);
  }
};
var createReactClass = require('create-react-class');
var TickTock = createReactClass({
  mixins: [SetIntervalMixin], // 使用 mixin
  getInitialState: function() {
    return {seconds: 0};
  },
  componentDidMount: function() {
    this.setInterval(this.tick, 1000); // 调用 mixin 上的方法
  },
  tick: function() {
    this.setState({seconds: this.state.seconds + 1});
  },
  render: function() {
    return (
      <p>
        React has been running for {this.state.seconds} seconds.
      </p>
    );
  }
});
ReactDOM.render(
  <TickTock />,
  document.getElementById('example')
);

如果完全不同的组件具有相似的功能,这将导致“交叉关注”的问题。为了解决这个问题,当使用createReactClass创建React组件时,引入mixin函数将是一个很好的解决方案。 更常见的用法是组件定期更新。这个函数可以很容易地用setInterval()实现,但需要注意的是,当不再需要它时,应该清除它以节省内存。React提供了一种生命周期方法,这样就可以知道何时创建或销毁了组件。让我们创建一个简单的mixin,它使用这些方法来提供一个简单setInterval()函数,该函数将在组件被破坏时自动清理。

class Greeting extends React.Component {
  // ...
}
Greeting.defaultProps = {
  name: 'Mary'
};

如果一个组件有多个mixin,并且在这些mixin中定义了相同的生命周期方法(例如,当一个组件被破坏时,几个mixin希望进行一些清理),则将调用这些生命周期方法。当使用mixin时,mixin将首先按照定义的顺序执行,然后调用组件上的相应方法。

JSX如何?

React不强制使用JSX。当不想在构建环境中配置JSX编译时,在React中不使用JSX会更方便。 每个JSX元素都简单地调用createElement的React Syntax sugar(component,props,…children)。因此,使用JSX可以做的任何事情都可以用纯JavaScript完成。

class Hello extends React.Component {
  render() {
    return <div>Hello {this.props.toWhat}</div>;
  }
}
ReactDOM.render(
  <Hello toWhat="World" />,
  document.getElementById('root')
);

如果想了解更多JSX转换为JavaScript的示例,可以尝试使用在线Babel编译器。 组件可以是字符串或React.component的子类。它也可以是正常功能。 如果不想键入React。createElement,通常会创建一个快捷方式:

const e = React.createElement;
ReactDOM.render(
  e('div', null, 'Hello World'),
  document.getElementById('root')
);

如果使用React,createElement的快捷方式几乎与使用React而不使用JSX一样方便。

以上就是React项目使用ES6解决方案及JSX使用示例详解的详细内容,更多关于React项目ES6 JSX使用的资料请关注我们其它相关文章!

(0)

相关推荐

  • React学习之JSX与react事件实例分析

    本文实例讲述了React学习之JSX与react事件.分享给大家供大家参考,具体如下: 1.JSX 1.1.表达式 在React中使用JSX来描述HTML页面,而且可以与js混合使用,使用JavaScript表达式时要将表达式包含在大括号里 const user = { firstName: 'Harper', lastName: 'Perez' }; const element = ( //将JSX语句保存在变量中 <h1> Hello, {formatName(user)}! {/* {}

  • react中JSX的注意点详解

    目录 1JSX是一个表达式 2JSX的属性 2.1驼峰命名 2.2style接收一个对象 3JSX标签没有子元素 4JSX防止注入攻击 5唯一父元素 总结 1 JSX 是一个表达式 JSX 是 JavaScript 的语法扩展,本质上是 React.createElement()方法的语法糖. Babel 会把 JSX 转译成一个名为 React.createElement() 函数调用,所以它被看作一个表达式. 这意味着你可以在 if 语句和 for 循环的代码块中使用 JSX,将 JSX 赋

  • React中的JSX  { }的使用

    目录 1.在JSX中使用{ } 2.在JSX中嵌套标签 3.{}中的样式和事件处理 4.在JSX中使用语句 在做react开发的时候,我们知道最后要通过render方法来将React元素挂载到真实的DOM上.而创建一个React元素,可以通过两种方式创建.(1)通过JSX方式(2)通过React.createElement()方法创建 而JSX的方式,最终也会被babel转换,变成通过React.createElement()方法进行创建.之所以这样子,是因为JSX能够很大程度的方便开发,可以少

  • React详细讲解JSX和组件的使用

    目录 一.React JSX 1.1 JSX简介 1.2 JSX表达式 1.3 JSX条件表达式 1.4 JSX循环表达式 1.5 JSX样式表达式 1.6 JSX注释表达式 二.React组件 2.1 类组件 2.2 函数组件 2.3 React Props 一.React JSX 1.1 JSX简介 JSX是全称是(JavaScript XML)按照React 官方的解释,JSX 是一个 JavaScript 的语法扩展,类似于模板语法,或者说是一个类似于 XML 的 ECMAScript

  • React项目使用ES6解决方案及JSX使用示例详解

    目录 不使用 ES6 绑定 JSX如何? 不使用 ES6 然而,在纯浏览器端使用ES6语法时,浏览器支持存在差异,这需要特殊处理才能正常运行. 支持ES2015桌面浏览器 Chrome:从51版开始,它可以支持ES6 97%的新功能. Firefox:53版本支持97%的ES6新功能. Safari:从版本10开始,ES6 99%的新功能都可以得到支持. IE:Edge 15可以支持96%的ES6新功能. Edge 14可以支持93%的新ES6功能.(IE7~11基本不支持ES6) class

  • vue项目网站全局置灰功能实现示例详解

    目录 1.前端独立实现 2.通过后台管理控制设置网站的整体置灰样式 1.前端独立实现 两种不同的逻辑,一种是前端自己实现,一种是结合后台管理系统来控制,网站是正常还是置灰. 直接在public文件夹下的index.html文件的html标签里加上style="filter:grayscale(100%)",总的就是<html style="filter:grayscale(100%)"> 2.通过后台管理控制设置网站的整体置灰样式 1.先给public文

  • vue3项目新用户引导组件driver.js示例详解

    好用的用户引导插件有 intro.js 和 driver.js 两个,对比了一下,最终还是使用了driver.js主要有以下原因: 用法简单 可以商用 总要选一个吧 项目使用的是vue3+ts因为多个地方需要使用引导,就直接做成组件使用不废话上代码 yarn add driver.js 或者 npm i driver.js 组件代码 <!-- * @Description: 新用户引导组件 * @LastEditTime: 2022-08-19 11:43:25 --> <templat

  • react项目从新建到部署的实现示例

    开展新项目 本文主要记录最近工作一个新项目从0-1的过程,主要记录3个节点,选型.运行时.上线. 项目选型 react 脚手架初始化,社区比较火的有cra(create-react-app)和umi,从以下几点进行对比最终选择了比较贴合项目的umi. 易用性,开箱即用.umi内置了许多功能,可是也带来很多限制,譬如对项目结构的规定提供自己生态的插件需要学习成本,cra初始化简洁选取模板即可开始,不需要额外的学习成本(即使vue玩家过来也没负担). 可拓展性,修改webpack配置.cra提供ej

  • React 路由使用示例详解

    目录 Router 简单路由 嵌套路由 未匹配路由 路由传参数 索引路由 活动链接 搜索参数 自定义行为 useNavigate 参考资料 Router react-router-dom是一个处理页面跳转的三方库,在使用之前需要先安装到我们的项目中: # npm npm install react-router-dom@6 #yarn yarn add react-router-dom@6 简单路由 使用路由时需要为组件指定一个路由的path,最终会以path为基础,进行页面的跳转.具体使用先看

  • react后台系统最佳实践示例详解

    目录 一.中后台系统的技术栈选型 1. 要做什么 2. 要求 3. 技术栈怎么选 二.hooks时代状态管理库的选型 context redux recoil zustand MobX 三.hooks的使用问题与解决方案 总结 一.中后台系统的技术栈选型 本文主要讲三块内容:中后台系统的技术栈选型.hooks时代状态管理库的选型以及hooks的使用问题与解决方案. 1. 要做什么 我们的目标是搭建一个适用于公司内部中后台系统的前端项目最佳实践. 2. 要求 由于业务需求比较多,一名开发人员需要负

  • React学习笔记之列表渲染示例详解

    前言 本文主要给大家介绍了关于React列表渲染的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧. 示例详解: 列表渲染也很简单,利用map方法返回一个新的渲染列表即可,例如: const numbers = [1, 2, 3, 4, 5]; const listItems = numbers.map((number) => <li>{number}</li> ); ReactDOM.render( <ul>{listItems}<

  • Vue微信项目按需授权登录策略实践思路详解

    项目采用Vue作为开发框架,用户浏览页面时有两种情况: 一种是需要用户先登录之后才能继续浏览: 另一种是用户无需登录即可随意浏览. 在无需用户登录的页面中,可能包含需要用户信息的操作,此时就需要用户登录之后方能进行后续操作.因此,需要对授权登录策略进行区分. 思路 1.一般而言,我们为微信开发的H5页面,进入页面的时候就进行鉴权,要求用户登录之后才能继续浏览.但由于产品需求,这个项目我们需要对不同页面的鉴权策略进行划分,按照一般与特殊进行设计: 2.一般情况,用户进入页面第一时间要求用户授权登录

  • ES6学习教程之Promise用法详解

    前言 promise用了这么多年了,一直也没有系统整理过.今天整理整理promise的相关东西,感兴趣的可以一起看一看.我尽量用更容易理解的语言来剖析一下promise 我准备分两篇文章来说明一下promise 一篇来理解和使用promise(本篇) 另一篇来从promise使用功能的角度来剖析下promise的源码(下一篇) 1.什么是Promise 我的理解是:实现让我们用同步的方式去写异步代码的一种技术.是异步解决方案的一种. 他可以将多个异步操作进行队列化,让它们可以按照我们的想法去顺序

  • react中使用antd及immutable示例详解

    目录 一.react中使用antd组件库 二.Immutable 2.1 深拷贝和浅拷贝的关系 2.2 immutable优化性能方式 2.3 immutable的Map使用 2.4 immutable的List使用 2.5 实际场景formJS 三.redux中使用immutable 一.react中使用antd组件库 运行命令create-react-app antd-react创建新项目: 运行命令npm i antd安装: 使用: import React from 'react' im

随机推荐