我是React的新手,正在尝试在我的网站中使用React TinyMCE Component。
我可以启动并运行一个基本的React应用程序但是当我尝试集成TinyMCE组件时,我在控制台中收到“未捕获的ReferenceError:未定义TinyMCE”错误。
从我有限的知识来看,似乎是使用节点“需要”功能?有没有使用没有Node的组件的方法?
我在Plunker中创建了this示例来显示问题,删除script.jsx文件中的以下行可以防止错误:
< TinyMCE content = "<p>This is the initial content of the editor</p>"
config = {
{
plugins: 'autolink link image lists print preview',
toolbar: 'undo redo | bold italic | alignleft aligncenter alignright'
}
}
/>
答案 0 :(得分:1)
你有两个问题。首先react-tinymce-min.js
尚未找到。因此,您需要以某种方式将其纳入您的项目。这种做死的方法就是将source复制到你的项目中。其次,因为您没有使用Webpack TinyMCE
被放入全局变量ReactTinymce
。 Edited plunk.
最终,您将要使用Webpack。这就是所有酷孩子都在使用的东西。它会让你的生活更轻松。
答案 1 :(得分:0)
对于任何有同样问题的人来说,这就是我最终的目标:
确保您有一个名为.babelrc的文件(包括。)
.babelrc
{
"presets": ["es2015"]
}
的package.json
{
"name": "demo",
"version": "1.0.0",
"description": "Demo",
"main": "app.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "PN",
"license": "ISC",
"dependencies": {
"babel-preset-react": "^6.3.13",
"react": "^0.14.6",
"react-dom": "^0.14.6",
"react-tinymce": "^0.4.0"
},
"devDependencies": {
"babel-core": "^6.4.0",
"babel-loader": "^6.2.1",
"babel-preset-es2015": "^6.3.13",
"webpack": "^1.12.11",
"webpack-dev-server": "^1.14.1"
}
}
webpack.config.js
module.exports = {
entry: "./main.js",
output: {
filename: "bundle.js"
},
module: {
loaders: [
{
test: /\.js$/,
exclude: /node_modules/,
loader: "babel",
query:
{
presets:['react']
}
}
]
},
resolve: {
extension: ['', '.js', '.jsx', '.es6']
}
}