gpt4 book ai didi

javascript - Browserify/Reactify - 未捕获的 ReferenceError : function is not defined

转载 作者:行者123 更新时间:2023-11-30 12:08:49 24 4
gpt4 key购买 nike

我正在尝试抽象我的代码,并且我在以下结构中有以下两个文件

main.js
components
- parent.js

主要.js

require('./components/Parent');

ReactDOM.render(
<Parent />,
document.getElementById('content')
);

组件/Parent.js

var Parent = React.createClass({
displayName: 'Parent',
render: function(){
return (
<div>
<div> This is the parent page. </div>
</div>
)
}
});

index.html

<div id="app">  
</div>

我运行以下 -

browserify -t reactify main.js -o main_js.js

这是它创建的 javascript

(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
require('./components/Parent');

ReactDOM.render(
React.createElement(Parent, null),
document.getElementById('content')
);

},{"./components/Parent":2}],2:[function(require,module,exports){
var Parent = React.createClass({
displayName: 'Parent',
render: function(){
return (
React.createElement("div", null,
React.createElement("div", null, " This is the parent page. ")
)
)
}
});

},{}]},{},[1]);

运行页面在第 5 行报错,即 React.createElement(Parent, null),

Uncaught ReferenceError: Parent is not defined

但是如您所见,文件已加载,那么为什么在文件中找不到它呢?

最佳答案

require('./components/Parent'); 更改为 var Parent = require('./components/Parent');

您需要指定分配给它的变量的名称。此外,如果您将它们放在不同的模块中,则需要导出模块。

// in ./components/Parent
module.exports = Parent;

关于javascript - Browserify/Reactify - 未捕获的 ReferenceError : function is not defined,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34426006/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com