当前位置: 首页 > 面试题库 >

ReactJS:React.render不是函数,React.createElement不是函数

上官鸿朗
2023-03-14
问题内容

当我试图在React版本15.2.0中使用这两个函数时,我在代码中发现了一个问题,尽管如此,我找到了一种解决方法,但是我想知道是否有更好的解决方案。

//app.jsx
var React = require('react');

var ThumbnailList = require('./thumbnail-list');

var options = {
     ThumbNailData: [{
     title : 'Download the ISO',
     number : 32,
     header : 'Learning React',
     description: 'The best library for creating fast and dynamic websites.',
     imageUrl : 'image source'
    },{
     title : 'Download the ISO',
     number : 64,
     header : 'Learning Gulp',
     description: 'Speed your development framework!',
     imageUrl : 'image source'
    }],
};

var element = React.createElement(ThumbnailList,options);
React.render(element, document.querySelector('.container'));

因此,每当我尝试运行index.html文件时,都不会显示任何内容,但是控制台会出现第一个错误: React.render不是function
。我发现发生这种情况是因为新版本的React需要使用react-dom,即

//app.jsx
var React = require('react-dom');

var ThumbnailList = require('./thumbnail-list');

var options = {
     ThumbNailData: [{
     title : 'Download the ISO',
     number : 32,
     header : 'Learning React',
     description: 'The best library for creating fast and dynamic websites.',
     imageUrl : 'image source'
    },{
     title : 'Download the ISO',
     number : 64,
     header : 'Learning Gulp',
     description: 'Speed your development framework!',
     imageUrl : 'image source'
    }],
};

var element = React.createElement(ThumbnailList,options);
React.render(element, document.querySelector('.container'));

现在问题已解决,但是当您尝试再次运行index.html时,出现了第二个问题: React.CreateElement不是一个函数。
我所做的是添加另一个需要反应的变量,即

var React = require('react-dom');
var React2 = require('react');
var ThumbnailList = require('./thumbnail-list');

var options = {
    ThumbNailData: [{
        title : 'Download the ISO',
        number : 32,
        header : 'Learning React',
        description: 'The best library for creating fast and dynamic  websites.',
        imageUrl : 'image-source'
    },{
        title : 'Download the ISO',
        number : 64,
        header : 'Learning Gulp',
        description: 'Speed your development framework!',
        imageUrl : 'image-source'
   }],
};

var element = React2.createElement(ThumbnailList,options);
React.render(element, document.querySelector('.container'));

简而言之,解决React.render问题

var React = require('react-dom')

解决React.createElement问题

var React2 = require('react')

我的问题是:

  1. 为什么react-dom使用React.createElement造成问题?

  2. 是因为这个新版本的React吗?

  3. 有没有更好的方法来解决这些问题而不必调用react-dom和react?

任何想法和意见表示赞赏;)


问题答案:

首先,从React v0.14开始,有一个名为的新软件包react-dom。它抽象化了您将运行React的“环境”,在您的情况下,它就是浏览器。

https://facebook.github.io/react/blog/2015/10/07/react-v0.14.html#two-
packages-react-and-react-
dom

因此,由于您现在有了两个软件包:“ react”来创建React组件,“ react- dom”来将React与浏览器“集成”,因此您需要调用它们每个提供的正确方法。

然后,回答您的问题:

为什么react-dom使用React.createElement造成问题?

具有包React.createElementreact不是 react-dom

是因为这个新版本的React吗?

是的,您无法再React.render(从package react)调用,而需要使用ReactDOM.render(从package
react-dom)。

有没有更好的方法来解决这些问题而不必调用react-dom和react?

我不认为这是一个“问题”,您只需要知道现在有一个特定的软件包即可操作DOM。而且,这是一种“良好”的模式,因为如果有时您想将组件呈现为HTML(使用服务器来呈现),则只需进行一些改动,您的代码就会相同。



 类似资料:
  • 问题内容: 我正在为无法解决的错误而烦恼。我有以下内容; JSON格式 和下面的jQuery 但是我收到一个错误,认为map.data未定义为函数?看着它,我不知道什么是行不通的,因为我已将其从以前使用的代码复制到新项目中。唯一不同的是JSON源。上一个没有[]括号之前的部分。这是什么让我失望吗? 问题答案: 对象,在JavaScript没有方法,它只是为数组,。 因此,为了使您的代码正常工作,请

  • 问题内容: 我有这段代码可用于从Arduino接收数据,但我想将数据发送回Arduino并在客户端页面上获得响应。我添加了侦听功能,但是从客户端页面发送数据时却不断获取信息。 test.js 问题答案: 您的价值不是应有的价值。 通常的做事方式是这样的: 但是我猜你的价值是这样的: 那不是同一回事。那就是模块句柄。但是,当您这样做时: 然后,是一个socket.io实例。您可以将侦听器绑定到实例,

  • 问题内容: 我正在尝试使用来运行任何按钮的功能。我在Firebug中遇到错误 document.getElementByClass不是函数 这是我的代码: 问题答案: 您可能是想(然后从结果节点列表中获取第一项): 您可能仍然会收到错误 不是功能 但是,在较旧的浏览器中,如果需要支持那些较旧的浏览器,则可以提供后备实现。

  • 编辑:阅读问题末尾的部分! 我的服务代码: 在我的组件中,我有这个提交功能: 这里和这里都有类似的错误。答案总是包含rxjs函数,但是我这样做了,所以我不太确定,为什么会出现这个错误。 编辑: 因此,实际的问题不是这个函数,而是主应用程序中我的路线前缺少“/”。js文件。解决了这个问题之后,问题就消失了。

  • 问题内容: 我有以下组件,该组件维护在特定元素上触发事件时更新的状态,并且在更新状态时将其作为道具传递给另一个组件。我目前正在尝试为什么我得到以下错误“ this.setState不是函数”,它很可能没有绑定到正确的上下文。但是我不确定,我这样做正确吗? 编辑: 我只是意识到上下文会在“onreadyStateChange”函数时发生更改,所以我在searchGif中做了以下操作 问题答案: 您正

  • 问题内容: 我将Webpack与firebase和firebase-admin一起使用。 要安装firebase,我跑了 我正在使用导入Firebase, 我也试过 我试过了 根据网络入门指南中的建议 但是,当我尝试使用时,出现错误 console.js:32 TypeError:firebase.auth不是函数 当我使用调试器进行检查时,我发现它实际上没有功能: 如何使用webpack将aut