@uiw/react-textarea
TypeScript icon, indicating that this package has built-in type declarations

4.22.3 • Public • Published

Textarea 多行文本输入框

Buy me a coffee Open in unpkg NPM Downloads npm version

标准的多行文本输入框。

import { Textarea } from 'uiw';
// or
import Textarea from '@uiw/react-textarea';

基础用法

import React from 'react';
import { Textarea } from 'uiw';

const Demo = () => (
  <div style={{ maxWidth: 300 }}>
    <Textarea placeholder="请输入内容" />
  </div>
)
export default Demo;

在表单中使用

<Form /> 表单中应用 <Textarea /> 组件

import React from 'react';
import { Form, Row, Col, Textarea, Button, Notify } from 'uiw';

const Demo = () => (
  <div>
    <Form
      onSubmitError={(error) => {
        if (error.filed) {
          return { ...error.filed };
        }
        return null;
      }}
      onSubmit={({initial, current}) => {
        const errorObj = {};
        if (!current.commit) {
          errorObj.commit = '内容为空,请输入内容';
        }
        if(Object.keys(errorObj).length > 0) {
          const err = new Error();
          err.filed = errorObj;
          Notify.error({ title: '提交失败!', description: '请确认提交表单是否正确!' });
          throw err;
        }
        Notify.success({
          title: '提交成功!',
          description: `表单提交成功,内容为:${current.commit},将自动填充初始化值!`,
        });
      }}
      fields={{
        commit: {
          children: <Textarea placeholder="请输入说明内容" />
        },
      }}
    >
      {({ fields, state, canSubmit }) => {
        return (
          <div>
            <Row>
              <Col style={{ maxWidth: 300 }}>{fields.commit}</Col>
            </Row>
            <Row>
              <Col fixed>
                <Button disabled={!canSubmit()} type="primary" htmlType="submit">提交</Button>
              </Col>
            </Row>
            <Row>
              <Col>
                <pre style={{ padding: 10 }}>
                  {JSON.stringify(state.current, null, 2)}
                </pre>
              </Col>
            </Row>
          </div>
        )
      }}
    </Form>
  </div>
)
export default Demo;

禁用

import React from 'react';
import { Textarea } from 'uiw';

const Demo = () => (
  <div style={{ maxWidth: 300 }}>
    <Textarea placeholder="请输入内容" disabled />
  </div>
)
export default Demo;

HTML Textarea

import React from 'react';
import { Textarea } from 'uiw';

const Demo = () => (
  <div style={{ maxWidth: 300 }}>
    <textarea className="w-textarea" placeholder="请输入内容" defaultValue="" />
  </div>
)
export default Demo;

Props

这是一个标准组件,与 HTML 中属性保持一致。

参数 说明 类型 默认值
placeholder 规定描述文本区域预期值的简短提示。 String -
disabled 禁用输入框 Boolean -

Package Sidebar

Install

npm i @uiw/react-textarea

Weekly Downloads

193

Version

4.22.3

License

MIT

Unpacked Size

13.5 kB

Total Files

12

Last publish

Collaborators

  • uiwjs
  • wcjiang