Skip to content

文本域 Textarea

用于多行输入

何时使用

  • 需要文本域输入较多内容时

基本使用

.lazy

默认情况下,v-model 会在每次 input 事件后更新数据 (IME 拼字阶段的状态例外)。你可以添加 lazy 修饰符来改为在每次 change 事件后更新数据

vue
<!-- 在 "change" 事件后同步更新而不是 "input" -->
<Textarea v-model:value.lazy="msg" />
Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
const value = ref('')
const lazyValue = ref('')
watchEffect(() => {
  console.log('value', value.value)
})
watchEffect(() => {
  console.log('lazyValue', lazyValue.value)
})
function onChange (e: Event) {
  console.log('change', e)
}
function onEnter (e: KeyboardEvent) {
  console.log('enter', e)
}
</script>
<template>
  <Space vertical :width="480">
    <Textarea v-model:value="value" placeholder="Basic usage rows 2" :rows="2" @change="onChange" @enter="onEnter" />
    <Textarea
      v-model:value.lazy="lazyValue"
      placeholder="Lazy usage rows 2"
      :rows="2"
      @change="onChange"
      @enter="onEnter"
    />
  </Space>
</template>

适应文本高度的文本域

Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const value = ref('')
</script>
<template>
  <Space :width="480">
    <Textarea
      v-model:value="value"
      placeholder="Autosize height based on content lines"
      auto-size
    />
  </Space>
</template>

自定义行数

Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const value = ref('')
</script>
<template>
  <Space :width="480">
    <Textarea
      v-model:value="value"
      placeholder="Autosize height with minimum and maximum number of lines"
      :auto-size="{ minRows: 2, maxRows: 5 }"
    />
  </Space>
</template>

带清除图标

Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const value = ref('')
</script>
<template>
  <Space :width="480">
    <Textarea v-model:value="value" placeholder="textarea with clear icon" allow-clear />
  </Space>
</template>

带数字提示

Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const value = ref('')
</script>
<template>
  <Space :width="480">
    <Textarea v-model:value="value" show-count :maxlength="10" />
  </Space>
</template>

禁用

Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const value = ref('')
</script>
<template>
  <Space :width="480">
    <Textarea v-model:value="value" disabled />
  </Space>
</template>

APIs

Textarea

参数说明类型默认值
width文本域宽度,单位 pxstring | number'100%'
allowClear可以点击清除图标删除内容booleanfalse
autoSize自适应内容高度boolean | {minRows?: number, maxRows?: number}false
disabled是否禁用booleanfalse
placeholder文本域输入的占位符stringundefined
maxlength文字最大长度numberundefined
showCount是否展示字数booleanfalse
value
v-model
文本域内容stringundefined

Events

名称说明类型
change文本域内容变化时的回调(e: Event) => void
enter按下回车的回调(e: Event) => void

Released under the MIT License.