私はreactプロジェクトのマークダウンエディターに取り組んでいます。 CodeMirrorをコードエディターとして使用したいのですが、webpackでビルドすると機能しないようです。
正直なところ、CodeMirrorはDOMツリーにあり、textAreaは非表示になっていますが、表示されるものはすべて次のとおりです。
そして
UPD:同じコードがcodepenで完璧に機能します。 webpackの問題だと思います。
いくつかのコード:
index.js
import React from 'react';
import ReactDOM from 'react-dom';
import {Editor} from './components';
const rootElement = document.getElementById('root');
ReactDOM.render(<Editor />, rootElement);
components/editor.js
import React, { Component } from 'react';
import cm from 'codemirror';
require('codemirror/mode/markdown/markdown');
export class App extends Component {
componentDidMount() {
this.codeMirror = cm.fromTextArea(this.refs.editor, {mode: 'markdown'})
}
render() {
return (
<div>
<textarea ref='editor' autoComplete='off' defaultValue='default value' />
</div>
);
}
}
server.js
var path = require('path');
var express = require('express');
var webpack = require('webpack');
var config = require('./webpack.config.dev');
var Host = 'localhost';
var PORT = 3000;
var app = express();
var compiler = webpack(config);
app.use(require('webpack-dev-middleware')(compiler, {
noInfo: true,
publicPath: config.output.publicPath
}));
app.get('*', function(req, res) {
res.sendFile(path.join(__dirname, '/app/index.html'));
});
app.listen(PORT, Host, function(err) {
if (err) {
console.log(err);
return;
}
console.log('Listening at http://' + Host + ':' + PORT);
});
およびwebpack.config.js
var path = require('path');
var webpack = require('webpack');
module.exports = {
devtool: 'eval',
entry: [
'webpack-hot-middleware/client',
'./app/index'
],
output: {
path: path.join(__dirname, 'dist'),
filename: 'bundle.js',
publicPath: '/static/'
},
plugins: [
new webpack.HotModuleReplacementPlugin(),
new webpack.NoErrorsPlugin()
],
module: {
loaders: [{
test: /\.js$/,
loaders: ['babel'],
include: path.join(__dirname, 'app')
}]
}
};
webpack gitter chat@ bebraw 私の質問に答えました:
Codemirrorはwebpackで動作しますが、追加の設定が必要です。レンダリングするには、CSSなどをいくつか持参する必要があります。 例