reactjs donnant une erreur Uncaught TypeError: la super expression doit être nulle ou une fonction, pas indéfinie

256

J'utilise reactjs.

Lorsque j'exécute le code ci-dessous, le navigateur dit:

TypeError non capturé: la super expression doit être nulle ou une fonction, non indéfinie

Tout indice sur ce qui ne va pas serait apprécié.

D'abord la ligne utilisée pour compiler le code:

browserify -t reactify -t babelify examples/temp.jsx  -o examples/public/app.js

Et le code:

var React = require('react');

class HelloMessage extends React.Component {
  render() {
    return <div>Hello </div>;
  }
}

MISE À JOUR: Après avoir brûlé dans hellfire pendant trois jours sur ce problème, j'ai constaté que je n'utilisais pas la dernière version de react.

Installez globalement:

sudo npm install -g react@0.13.2

installer localement:

npm install react@0.13.2

assurez-vous que le navigateur utilise également la bonne version:

<script type="text/javascript" src="react-0.13.2.js"></script>

J'espère que cela sauve quelqu'un d'autre de trois jours d'une vie précieuse.

Duke Dougal
la source
111
Depuis la version 0.14.8, vous pouvez toujours l'obtenir si vous faites quelque chose comme extends React.component(en minuscules c).
Kevin Suttle
12
@Kevin veut juste reformuler, en gros Si vous avez une faute de frappe quelque part, dans mon cas c'était Componentsau lieu de Component :). Votre commentaire a aidé BTW
P-RAD
Mon problème était que je n'exportais pas la classe à la fin du fichier ...
R01010010
2
J'ai fait React.Components (pluriel), la droite est React.Component (singulier) Ow good ... comment ai-je raté ça ...
Ismael
5
@Kevin Suttle Votre commentaire est en fait plus utile que la réponse
Mick Jones

Réponses:

325

Noms de classe

Premièrement, si vous êtes certain que vous étendez à partir de la classe correctement nommée, par exemple React.Component , pas React.component ou React.createComponent, vous devrez peut-être mettre à niveau votre version de React. Voir les réponses ci-dessous pour plus d'informations sur les classes à partir desquelles.

Upgrade React

React ne prend en charge que les classes de style ES6 depuis la version 0.13.0 (voir leur blog officiel sur l'introduction du support ici .

Avant cela, lors de l'utilisation:

class HelloMessage extends React.Component

vous tentiez d'utiliser des mots clés ES6 ( extends) pour sous-classer à partir d'une classe qui n'était pas définie à l'aide d'ES6 class. C'est probablement pourquoi vous avez eu un comportement étrange avec les superdéfinitions, etc.

Donc, oui, TL; DR - mise à jour vers React v0.13.x.

Dépendances circulaires

Cela peut également se produire si vous avez une structure d'importation circulaire. Un module en importe un autre et inversement. Dans ce cas, il vous suffit de refactoriser votre code pour l'éviter. Plus d'informations

Jack Preston
la source
202
Pour tout le monde qui a ce problème, mais la mise à jour de React n'est pas la solution - faites défiler plus bas vers les autres réponses, il pourrait s'agir d'une simple faute de frappe. Dans mon cas, c'était une définition de classe utilisant React.componentau lieu deReact.Component
Christian Benke
1
Pour info, l'ancienne classe peut également être étendue avec extends. Essayez ceci var x = function(){}; class y extends x {}
Mouneer
2
C'était une structure d'importation circulaire pour moi. Merci de m'avoir sauvé beaucoup d'heures de débogage!
DrunkDevKek
4
Juste FYI. J'ai récemment eu la même erreur en dépit d'être sur ReactJS 16.x. Il s'avère que j'avais une faute de frappe dans cette ligne: class App extends React.Component () {...}- qui devrait être corrigée class App extends React.Component {...} (sans le ()à la fin)
Atlas7
1
Composante «C» majuscule! #facepalm
David
127

Cela signifie que vous voulez quelque chose de sous-classe, qui devrait être Class, mais est undefined. Les raisons peuvent être:

  • faute de frappe Class extends ..., donc vous étendant la variable non définie
  • typo in import ... from, donc vous importez undefineddu module
  • le module référencé ne contient pas la valeur, vous voulez importer (par exemple module obsolète - cas avec React), donc vous importez une valeur non existante ( undefined)
  • faute de frappe dans la export ...déclaration du module référencé , il exporte donc une variable non définie
  • module manquant exportdu tout référencé , donc il exporte justeundefined
Vaclav Novotny
la source
23
Dans mon cas, il s'agissait d'un composant en minuscule dans React.Component.
Statistiques d'apprentissage par l'exemple du
3
Dans mon cas, c'était une classe auto-écrite qui n'était pas correctement importée. J'importais la classe exportée par défaut via import {Foo} from 'bar'au lieu de import Foo from 'bar'. Ont donc voté.
xtra
4
Ne faites pas cela non plus: class Thing extends React.Component() {- J'ai dû retirer le()
activedecay
Dans mon cas, cette erreur a été causée par la création accidentelle d'une référence circulaire par ce que j'importais (la classe que je voulais étendre à la sous-classe) dans la fonction de rendu de mes composants. Lorsque j'ai essayé d'exécuter / rendre la sous-classe car la superClasse n'était pas encore créée, elle n'était pas définie.
Leon
^ Causé par une référence circulaire pour moi aussi.
Cailen
90

Cela peut également être causé par une erreur de frappe, donc au lieu de ComponentC majuscule, vous avez componentavec c inférieur, par exemple:

React.component //wrong.
React.Component //correct.

Remarque: La source de cette erreur est peut-être parce qu'il y a Reactet nous pensons automatiquement que ce qui vient ensuite devrait être une méthode ou une propriété de réaction commençant par une lettre minuscule, mais en fait c'est une autre classe ( Component) qui devrait commencer par une lettre majuscule .

ismnoiet
la source
2
hein, étrangement, cette erreur n'est pas détectée lors de l'étape de construction du webpack, mais elle apparaîtra au moment de l'exécution.
worc
31

Dans mon cas, avec react-native, l'erreur était que j'avais

import React, {
  AppRegistry,
  Component,
  Text,
  View,
  TouchableHighlight
} from 'react-native';

au lieu de

import React, { Component } from 'react';
import {
  AppRegistry,
  StyleSheet,
  Text,
  View,
  Image,
  AsyncStorage
} from 'react-native';
tonatiuhnb
la source
2
Cela a fonctionné dans mon cas! La documentation fournie dans le site
react
Merci, le composant devrait importer à partir de 'react'
xyz
15

J'ai vécu cela en manquant une instruction d'exportation pour la classe JSX.

Par exemple:

class MyComponent extends React.Component {
}
export default MyComponent // <- add me
Isocyanate d'allyle
la source
15

Vous pouvez également le recevoir si vous essayez de l'exécuter React.Componentavec une erreur ()dans votre définition de classe.

export default class MyComponent extends React.Component() {}
                                                        ^^ REMOVE

Ce que j'arrive parfois à faire lorsque je convertis un composant fonctionnel sans état en classe.

Adam Terlson
la source
C'était le problème pour moi. très idiot. Merci beaucoup!
bstst
14

J'ai vu cette erreur lorsque vous avez une dépendance circulaire.

class A extends B {}
class B extends C {}
class C extends A {}
Doug
la source
10

Pour toute autre personne, qui peut développer ce problème. Vous pouvez également vérifier que la componentméthode en React.Componentest en majuscule. J'ai eu le même problème et ce qui l'a causé, c'est que j'ai écrit:

class Main extends React.component {
  //class definition
}

Je l'ai changé en

class Main extends React.Component {
  //class definition
}

et tout a bien fonctionné

Van_Paitin
la source
6

J'ai obtenu ceci quand j'ai eu une faute de frappe sur mon importation:

import {Comonent} from 'react';
Matthew Herbst
la source
J'ai également obtenu ceci avec étend React.Components au lieu de React.Component (no s).
Pierre Maoui
1
J'ai aussi obtenu ceci mais pour avoir tapé la petite première lettre d'un composant - ... étend React.component {}
Ivan Topić
5

Vérifiez que les classes que vous étendez existent réellement, peu de méthodes React sont dépréciées, il peut également s'agir d'une erreur de frappe 'React.Components'au lieu de'React.Component'

Bonne chance!!

Ignace Andrew
la source
Dans mon cas, j'utilisais à la React.componentplace de React.Component(remarquez le "C" majuscule qui me manquait)
Javis Perez
4

Je vais apporter une autre solution possible, une qui a fonctionné pour moi. J'utilisais l'index de commodité pour collecter tous les composants dans un seul fichier.

Je ne crois pas au moment de la rédaction de ce document, il est officiellement pris en charge par babel, et jette une frappe typographique - mais je l'ai vu utilisé dans de nombreux projets et est certainement pratique.

Cependant, lorsqu'il est utilisé en combinaison avec l'héritage, il semble jeter l'erreur présentée dans la question ci-dessus.

Une solution simple est, pour les modules qui agissent comme des parents doivent être importés directement plutôt que via un fichier d'index de commodité.

./src/components/index.js

export Com1 from './com-1/Com1';
export Com2 from './com-2/Com2';
export Com3 from './com-3/Com3';
export Parent1 from './parent/Parent1';

./src/components/com-1/Com1.js

import { Com2, Com3 } from '../index';

// This works fine
class Com1 {        
    render() {
        return (
            <div>
                <Com2 {...things} />
                <Com3 {...things} />
            </div>
        );
    }
}

./src/components/com-3/Com3.js

import { Parent } from '../index';

// This does _not_ work
class Com3 extends Parent {        
}

./src/components/com-3/Com3.js

import Parent from '../parent/Parent';

// This does work
class Com3 extends Parent {        
}
Chris
la source
Cela m'a aidé à comprendre ce que j'avais fait de mal. J'ai accidentellement encapsulé le nom du composant dans {} dans ma déclaration d'importation. Différence subtile. Il peut être difficile de repérer cette erreur.
Dennis W
4

Cela a fonctionné pour moi:

import React, {Component} from 'react';
Armen
la source
4

Webpack 4 morceaux et hachages avec uglification par TerserPlugin

Cela peut se produire lorsque Webpack utilise des morceaux et des hachages avec minification et déglification via TerserPlugin (actuellement sur la version 1.2.3). Dans mon cas, l'erreur a été réduite à l'uglification par le plugin Terser de mon vendors.[contenthash].jsbundle qui contient mon node_modules. Tout fonctionnait sans utiliser de hachage.

La solution consistait à exclure le bundle dans les options d'uglification:

optimization: {
  minimizer: [
    new TerserPlugin({
      chunkFilter: (chunk) => {
        // Exclude uglification for the `vendors` chunk
        if (chunk.name === 'vendors') {
          return false;
        }
        return true;
      },
    }),
  ],
}

Plus d'informations

Anders Steinrud
la source
Cela a en effet résolu le problème pour moi, mais j'ai pu identifier le coupable et donc à la fin j'ai pu appliquer l'ugglification. Voir ma réponse - réagir-éblouir.
Erez Cohen
J'ai réduit le plugin terser, en changeant finalement le script de réaction à la version 3.2.0 a résolu le problème pour moi.
avck
3

J'ai le même problème, il suffit de passer de Navigatorà{Navigator}

import Navigator from 'react-native-deprecated-custom-components'
// to
import {Navigator} from 'react-native-deprecated-custom-components'
Mike Nguyen
la source
1
en gros, cela devrait correspondre comme ceci: export Foo ... import { Foo } - ou - export default Foo ... import Foo
dpren
3

Pas correct pour cette réponse, mais pour d'autres avec la même erreur, mon erreur ridiculement stupide pourrait potentiellement aider.

Bêtement, mon problème était d' utiliser la notation de fonction en incluant () après le nom de la classe .

Assurez-vous que votre syntaxe est correcte. Et vous avez importé et exporté tous les composants / modules externes avec les noms et chemins corrects.

Ce modèle devrait fonctionner correctement si une nouvelle version de react est installée:

import React, { Component } from 'react'

class ExampleClass extends Component {

    render(){
        return(
            <div>

            </div>
        )
    }
}

export default ExampleClass 
Harry
la source
3

Mes conditions

  • Create-React-App
  • React-scripts v3.2
  • Éditeur de texte riche Froala v3.1
  • Le mode de développement a bien fonctionné
  • La version de production a été rompue avec l'erreur mentionnée dans la question

Solution à mon problème

Rétrograder Froala vers la v3.0.

Quelque chose dans la v3.1 a cassé notre processus de construction de l'application Create React.

Mise à jour: utilisez les scripts React v3.3

Nous avons découvert qu'il y avait un problème entre React Scripts 3.2 et Froala 3.1.

La mise à jour de React Scripts v3.3 nous a permis de passer à Froala 3.1.

Daniel Tonon
la source
1
Je t'aime. Je veux venir te trouver et t'embrasser les pieds !!!!!!!!!!!!!!!!!!!!!!!!! (Nightmare all-nighter over)
GaddMaster
Je n'utilise pas l'application create react, mais je suis confronté au même problème sur prod avec froala 3.1. Pouvez-vous expliquer quel était le problème ici?
Karan Jariwala
2

J'ai écrit

React.component

au lieu de React.Component C'était mon problème)) et cherchait cela plus d'une demi-heure.

Руслан
la source
2

Dans mon cas, j'utilisais:

class Root extends React.Component() {
// THIS IS WORNG
// After React.Component () <- WRONG!!
}

ce qui était faux mais correct est:

class Root extends React.Component {
// THIS IS CORRECT
// That -> '()' after React.Component was typo
}

assurez-vous également qu'il n'y a
React.Component
PAS
ˣ React.componentouReact.Components

Kush Gautam
la source
Bienvenue chez SO. Il semble clair que le PO n'a pas commis cette erreur car il a déjà inclus le bon formulaire dans la question. Avez-vous eu la même erreur que OP mais avec une cause différente?
Eduardo
Oui, j'obtenais la même erreur que OP, mais j'ai trouvé que la cause était différente et j'espère que cela aidera les autres.
Kush Gautam
2

Un package tiers peut être à l'origine de ce problème. Dans notre cas, c'était une réaction éblouissante . Nous avons des paramètres similaires à ceux de @steine ​​( voir cette réponse ci-dessus ).

Afin de trouver le paquet problématique, j'ai exécuté la construction du webpack localement avec le mode de production et j'ai donc pu trouver le paquet problématique dans la trace de la pile. Donc, pour nous, cela a fourni la solution et j'ai pu garder l'ugification.

Erez Cohen
la source
1

En utilisant Babel (5.8), j'obtiens la même erreur si j'essaie d'utiliser l'expression export defaulten combinaison avec une autre export:

export const foo = "foo"
export const bar = "bar"
export default function baz() {}
Griffosx
la source
1

Voici une réponse:

import React, { Component } from 'react'; // NOT 'react-dom'
Viktor Velev
la source
exactement ma faute de frappe
Evandro Pomatti
1

Dans mon cas, j'ai corrigé cette erreur en export default class yourComponent extends React.Component() {}passant à export default class yourComponent extends React.Component {}. Oui, supprimer les parenthèses a ()corrigé l'erreur.

Jeff Tian
la source
1

J'ai rencontré cette erreur lors de l'importation d'un composant comme:

import React, { Components } from 'react';

au lieu de

import React, { Component } from 'react';
Ashvini Maurya
la source
1

Regardez si vous avez une erreur de frappe dans votre importation ou votre génération de classe, ce pourrait être simplement cela.

HoCo_
la source
1

Passez import React from 'react-domà import React, {Component} from 'react'
Et changez class Classname extends React.Componentà class Classname extends Component
Si vous utilisez la dernière version de React (16.8.6 à partir de maintenant) .

Neeraj Sewani
la source
0

Si vous recevez cette erreur et utilisez Browserify et browserify-shim (comme dans une tâche Grunt), vous avez peut-être vécu un moment stupide comme je l'ai fait où vous avez involontairement dit browserify-shimde traiter React comme faisant déjà partie de l'espace de noms global (par exemple, chargé à partir d'un CDN).

Si vous souhaitez que Browserify inclue React dans le cadre de la transformation, et non un fichier séparé, assurez-vous que la ligne "react": "global:React"n'apparaît pas dans la "browserify-shim"section de votre packages.jsonfichier.

Lachlan McD.
la source
Comment éviter Uncaught Error: Cannot find module 'react'après avoir supprimé la configuration de browserify-shim? Fondamentalement, je veux continuer à réagir en tant que dépendance externe, mais browserify ne semble pas comprendre comment créer le bundle et garder React externe. Cela peut ou non être dû au fait que le module que j'inclus dans mon point d'entrée browserify a réagi comme une dépendance.
dmarr
FWIW, la suppression de react de la configuration de browserify-shim et le fait de laisser browserify réconcilier la dépendance entraîne normalement toujours le problème de l'OP.
dmarr
0

Cela peut également se produire si vous l'avez utilisé à la requireplace de importvotre code.

bhagyas
la source
0

Cela m'est arrivé aussi quand j'ai utilisé ceci:

class App extends React.Component(){

}

Au lieu du bon:

class App extends React.Component{

}

Remarque: - () dans le premier qui est la principale cause de ce problème


la source
0

Pour ceux qui utilisent react-native:

import React, {
  Component,
  StyleSheet,
} from 'react-native';

peut produire cette erreur.

Alors que référencer reactdirectement est la manière la plus stable de procéder:

import React, { Component } from 'react';
import { StyleSheet } from 'react-native';
Mari Gallegos
la source
0

Dans mon cas, c'est le changement de React.Element en React.Component qui corrige cette erreur.

SkorpEN
la source