随笔 - 2649  文章 - 2452  评论 - 0  阅读 - 80424

<input>

#简介

Weex 内置的 <input> 组件用来创建接收用户输入字符的输入组件。 <input> 组件的工作方式因 type 属性的值而异,比如 textpasswordurlemailtel 等。

注意

此组件不支持 click 事件。请监听 inputchange 来代替 click 事件。

#子组件

<input> 不支持子组件。

#属性

key 类型 描述 默认值 备注
type string 控件的类型 text type 值可以是 text,date,datetime,email, password,tel,time,url,number 。每个 type 值都符合 W3C 标准。 其中,date 和 time 会使用系统默认组件(Android + IOS)查看示例
value string 组件的默认内容
placeholder string 提示用户可以输入什么。 提示文本不能有回车或换行
autofocus boolean 布尔类型的数据,表示是否在页面加载时控件自动获得输入焦点
maxlength nubmer 一个数值类型的值,表示输入的最大长度
return-key-type string 键盘返回键的类型(即手机输入法右下角回车按钮的地方) img 支持 defalut;go;next;search;send,done 查看示例
singleline boolean 控制内容是否只允许单行 true
max string 控制当 type 属性为 date 时选择日期的最大时间,格式为 yyyy-MM-dd
min string 控制当 type 属性为 date 时选择日期的最小时间,格式为 yyyy-MM-dd
upriseOffsetv0.21+ & iOS number 当键盘弹起可能盖住输入框时,页面整体会上移。这个属性指定键盘上边缘与输入框下边缘的间隙。使用 iOS 系统坐标,默认是 20。 20
hideDoneButtoniOS number 隐藏键盘上面的完成栏 false

#样式

#placeholder-color

placeholder 字符颜色。默认值是 #999999

#伪类

支持:

  • :active
  • :focus
  • :disabled
  • :enabled

#通用样式

支持所有通用样式

  • 盒模型
  • flexbox 布局
  • position
  • opacity
  • background-color

查看 组件通用样式

#事件

  • 通用事件 支持所有通用事件

  • input

    . 当输入状态时,会不断触发。

    • @param value: 当前文本。
  • change

    . 当用户完成了输入时触发。

    • @param value: 当前文本。
  • focus. 当输入框获得焦点时触发。

  • blur. 当输入框失去焦点时触发。

  • return

    . 当用户点击了“回车”按钮时触发,会返回此时“回车”按钮的动作类型。

    • @param value: 当前文本。
    • @param returnKeyType, "default" | "go" | "next" | "search" | "send" | "done".
  • keyboard

    . 当键盘弹起或收起时触发。

    • @param isShow: boolean, 显示或隐藏键盘。
    • @param keyboardSize: 键盘的尺寸,以前端使用的样式单位返回。

#组件方法

#focus() 0.8+

input 组件聚焦。

#blur() 0.9+

input 组件中移除焦点并关闭软键盘(如果它具有焦点)。

#setSelectionRange(selectionStart, selectionEnd) 0.11+only support android & ios

设置文本选区

key 类型 描述
selectionStart number 设置文本选区的起始点
selectionEnd number 设置文本选区的起终点

#getSelectionRange(function(params){}) 0.11+only support android & ios

获取文本选区

key 类型 描述
params.selectionStart number 文本选区的起始点
params.selectionEnd number 文本选区的起终点

#setTextFormatter(params) 0.18+only support android & ios

这是一个非常有用的特性,可以对 input 设置一组对输入的内容进行实时格式化的规则

key 类型 描述
params.formatRule regexp 格式化匹配的正则表达式
params.formatReplace regexp 格式化匹配后用于替换的内容
params.recoverRule regexp 从格式化后的内容还原原始内容的正则表达式
params.recoverReplace regexp 还原原始内容时用于替换的内容

约束

目前不支持 this.$el(id).value = '' 这种方式改写 input value。只支持在 <input> 组件的 input、change 事件中改写。

#Vue 示例

#Rax 示例

rax-textinput<textarea> 组件的上层封装,抹平了 Web 和 Weex 的展现

import { createElement, render } from "rax";
import Driver from 'driver-universal';
import TextInput from "rax-textinput";

function App() {
  return (
    <TextInput autoFocus={true} />
  );
}

render(<App />, document.body, { driver: Driver });

rax-textinput 文档

posted on   AtlasLapetos  阅读(5)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示