文本输入组件允许用户输入和编辑文本。
ID
: 组件ID,可用于在脚本或模板中引用该组件。类型
: 设置文本组件的类型,支持单行文本,密码,多行文本三种。占位符
: 设置文本组件的占位符文本。尺寸
: 设置文本组件的尺寸,支持默认和小型,大型三种。透明
: 设置文本组件是否透明。清空
: 设置文本组件是否显示清空按钮。计数
: 设置文本组件是否显示输入计数。最大长度
: 设置文本组件的最大输入长度。前缀
: 设置文本组件的前缀文本。后缀
: 设置文本组件的后缀文本。选项
: 设置文本组件的选项列表, 仅单行文本类型支持。脚本
: 定义组件事件处理函数或其他功能函数。坐标X
: 设置文本坐标X取值。坐标Y
: 设置文本坐标Y取值。坐标Z
: 设置文本坐标Z取值。高度
: 设置文本高度取值。宽度
: 设置文本宽度取值。变更
: 当文本内容变更时触发的事件。回车
: 当按下回车键时触发的事件。$this
$this
为当前组件实例,您可以通过 $this
对象调用组件的各种方法。
▲ 组件初始化
void init()
当组件存在init
方法时,组件初始化时会调用该方法。
脚本示例:
export function init() {
// your code here
}
▲ 设置/获取当前值
string value(string value)
请求参数:
value
: <字符串> 可选项, 设置当前开关值。返回值:<字符串> 当前开关值
模板示例:
{{$widget("input").value()}}
脚本示例:
// 设置输入框值
$this.value("hello");
$widget("input").value("hello");
// 获取输入框值
let value = $this.value();
let value = $panel.widget("input").value();
$panel
$panel
对象为当前面板实例,您可以通过 $panel
对象调用面板的各种方法。
▲ 设置/获取变量
string variable(string name, string value=undefined)
请求参数:
name
: <字符串> 必选项, 变量名称。value
: <字符串> 可选项, 设置变量值。返回值:<字符串> 变量值
脚本示例:
// 设置变量值
$panel.variable("name", "value");
// 获取变量值
let value = $panel.variable("name");
▲ 获取组件实例
object widget(string id)
请求参数:
id
: <字符串> 必选项, 组件ID。返回值:<对象> 组件实例
脚本示例:
// 获取组件实例
let widget = $panel.widget("switch");
// 获取开关值
let value = widget.value();
$
脚本上下文 $
是一个全局对象, 包含常用的全局函数和对象。
▲ 延时给定的毫秒数
async msleep(Integer ms)
例如 :
await $.msleep(1000);
▲ 显示确认对话框
async confirm(String message)
参数:
message
: 消息内容返回值: true
,否则返回 false
。
例如 :
let confirmed = await $.confirm("Are you sure?");
if ( confirmed ) {
$.alert("yes");
} else {
$.alert("no");
}
▲ 显示消息对话框
async alert(String message, String type=undefined)
参数:
message
: 消息内容type
: 消息类型,可选值为 error
、warning
, alert
。默认为 alert
。例如 :
$.alert("hello world");
// 显示错误信息
$.alert("hello world", "error");
// 显示警告信息
$.alert("hello world", "warning");
▲ 显示Toast消息
async toast(String message, String type=undefined)
参数:
message
: 消息内容type
: 消息类型,可选值为 success
, error
、warning
, info
。默认为 info
。例如 :
$.toast("hello world");
// 显示错误信息
$.toast("hello world", "error");
// 显示警告信息
$.toast("hello world", "warning");
▲ 显示通知消息
async notify(String title, String message, String type=undefined)
参数:
title
: 消息标题message
: 消息内容type
: 消息类型,可选值为 success
, error
、warning
, info
。默认为 info
。例如 :
$.notify("hello", "hello world");
// 显示错误信息
$.notify("hello", "hello world", "error");
// 显示警告信息
$.notify("hello", "hello world", "warning");
▲ 生成随机数
Integer random(Integer min, Integer max)
参数:
min
: 最小值max
: 最大值返回值:
例如 :
let value = $.random(1, 100);
▲ 生成随机字符串
String randomString(Integer length)
参数:
length
: 字符串长度返回值:
例如 :
let value = $.randomString(10);
▲ 执行指令
async execute(String name, Any params)
例如 :
let response = await $.execute(
"文件夹/指令名称", // 指令路径
{"name": "sige"} // 指令参数
);
// 等待1秒,用于等待指令执行完成
await $.msleep(1000);
// 读取指令执行结果
let text = response.readAs('text');
// 结束指令执行
response.cancel();
▲ 调用指令
async call(String name, Any params)
调用和执行指令的区别是, 调用模式下会在接收到响应内容后立即返回, 而执行模式下会持续接收响应内容。
例如 :
let response = await $.call(
"文件夹/指令名称", // 指令路径
{"name": "sige"} // 指令参数
);
▲ 获取环境变量
String env(String name, defaultValue=nul)
根据给定的环境变量名称获取环境变量的值, 当环境变量不存在时返回默认值。
例如 :
let value = $.env("name");
// 获取环境变量,如果不存在则返回默认值
let value = $.env("name", "default");