因为我是 JavaScript 和 React 的新手,所以我真的很难弄清楚正确的语法。
这是我的问题:
_handleDrop(files)
应该调用该函数,_validateXML(txt)
但没有调用。我收到此错误Uncaught TypeError: this._validateXML is not a function
,但无法弄清楚原因。回调_handleDrop(files)
工作正常。
当我尝试这种语法时,_validateXML:function(txt)
我在编译时立即出错。那是因为 ecmascript 吗?
import React from 'react';
import './UploadXML.scss';
import Dropzone from 'react-dropzone';
import xml2js from 'xml2js';
export default class UploadXML extends React.Component {
constructor() {
super();
this._validateXML = this._validateXML.bind(this);
}
_validateXML(txt) {
console.log('Received files: ', txt);
}
_handleDrop(files) {
if (files.length !== 1) {
throw new Error("Please upload a single file");
}
var file = files[0];
console.log('Received files: ', file);
this._validateXML(file);
}
render() {
return (
<div>
<Dropzone onDrop={this._handleDrop} multiple={false}>
<div>Try dropping some files here, or click to select files to upload.</div>
</Dropzone>
</div>
);
}
}