在我正在调用的app.jsx文件中说:
var Main = require('./components/main.jsx');
ReactDOM.render(
<Main />, document.getElementById('container')
);
在我的main.jsx文件中,我想从不同的文件中调用两个反应类:
var comp1 = require('./comp1.jsx')
var comp2 = require('./comp2.jsx')
const MyMainComponent = React.createClass({
return(
<comp1></comp1>
<comp2></comp2>
);
});
module.exports = MyMainComponent;
在我的comp1文件中,我有一个简单的按钮和对话框:
var comp1 = React.createClass({
return(
<RaisedButton label="comp1" primary={true} onTouchTap={this._handleTouchTap} />
<dialog name = "test"></dialog>
_handleTouchTap: function(){
test.show()
};);
在我的comp2文件中,我有与comp1.jsx完全相同的代码,除了我重命名按钮。基本上当文档加载main.jsx时,我希望两个组件(comp1和comp2)彼此相邻加载。我编写了上面的代码,所以我不确定一般原则或语法是否正确,但我在很高的层次上询问如何实现上述目标。谢谢
答案 0 :(得分:1)
我认为您正在寻找的是异步模块定义(AMD)。 您可以使用requirejs实现它。
首先你必须配置它,你可以在app.js文件或任何你想要的地方这样做:
require.config({
paths: {
react: 'vendor/react',
reactDOM: 'vendor/react-dom',
JSXTransformer: 'vendor/JSXTransformer'
}
});
require(['reactDOM', 'jsx!main'], function(ReactDOM, Main) {
ReactDOM.render(<Main />, document.getElementById('container'));
});
加载库后,您可以像这样定义模块:
comp1.jsx (或其他任何模块)
define(['react'], function(React) {
var Comp1 = React.createClass({
render: function() {
return (
)
}
});
return Comp1;
});
<强> main.jsx 强>
define(['jsx!comp1', 'jsx!comp2'], function(Comp1, Comp2) {
var Main = React.createClass({
render: function() {
return (
<section>
<Comp1 />
<Comp2 />
</section>
);
}
});
return Main;
});
最后,在您的HTML文件中:
<script data-main="js/app" src="js/vendor/require.js"></script>
如果你是初学者,这看起来很复杂,但是在处理大型项目时这是值得的,所以最好养成习惯。
我还恳请你拿一些关于编程的书。尝试Javascript好的部分,以及务实的程序员