Я создаю приложение, в котором можно подписать указателем.
Я установил response-canvas-signature .
Теперь мне нужно получить подпись с холста и показать ее как всплывающее окно, а в их файлах Readme сказано, что есть функция toDataURL()
toDataURL (mimetype, encoderOptions): base64string, возвращает изображение подписи в виде URL-адреса данных
Там говорится, что они доступны через API
API
Все методы API требуют ссылки на SignatureCanvas для использования и являются методами экземпляра ссылки. <SignatureCanvas ref={(ref) => { this.sigCanvas = ref }} />
Однако я не могу получить доступ к этой или любой другой функции, описанной там.
Я пытался использовать useRef()
, createRef()
, но все равно ничего. Возможно я просто не делаю это правильно.
Найдите ниже родительский компонент без лишних строк:
import React, { createRef } from 'react';
import ReactCanvas from 'react-signature-canvas';
interface IProps {}
interface IState {}
export default class App extends React.Component<IProps, IState> {
constructor(props: IProps) {
super(props);
this.state = {};
}
render() {
return (
<div className="content-area">
<ReactCanvas penColor='black' canvasProps={{width: 353, height: 120}} />
</div>
);
}
}
Я попытался создать ссылку, например, private myRef = createRef<ReactCanvas>()
, а затем использовать ее
const canvasRef = this.myRef.current
if (canvasRef) {
canvasRef.props.toDataURL('image/png', 1);
}
и там написано
Свойство 'toDataURL' не существует для типа 'Readonly & Readonly <{children ?: ReactNode; }>».
ref
в дочернем элементе, как это <ReactCanvas penColor='black' canvasProps={{width: 353, height: 120}} ref={this.myRef} />
Не могли бы вы показать, как я должен это сделать, или даже направление / предложение будут очень благодарны.