【SAP UI5 控件学习】DAY02 Input组PartII

news2024/10/5 15:36:00

1. CheckBox控件

1.1 最普通的CheckBox

在这里插入图片描述

<CheckBox text="Option a" selected="true" />

如果需要设置选中状态,需要设置selected属性为true

1.2 部分选中CheckBox

在这里插入图片描述

<CheckBox text="Option partially selected" selected="true" partiallySelected="true" />

1.3 带有不同颜色的CheckBox

在这里插入图片描述

通过设置不同的valueState来使CheckBox显示不同的颜色

  • Warning为橙色
  • Error为红色
  • Information为蓝色

1.4 Wrapping属性的CheckBox

对于一些文字比较长的CheckBox,默认的wrapping属性为false,导致文字显示不全,如下图所示:
在这里插入图片描述
当设置wrapping属性为true时,显示不全会自动换行,保证所有的内容都可以显示出来,如下图所示:
在这里插入图片描述

2. 拾色器Color Picker

可以结合ValueHelper实现在输入框中点击后弹出一个拾色器,选择相应颜色后将颜色信息填充到输入框中。前端界面如下:
在这里插入图片描述
前端代码如下:

<mvc:View
		xmlns:mvc="sap.ui.core.mvc"
		controllerName="sap.ui5.walkthrough.controller.App"
		xmlns="sap.m">
	<Table id="samplesTable" headerText="Color Picker in a Popover" class="sapUiLargeMarginBottom">
		<columns>
			<Column width="30%">
				<Text text="Description"/>
			</Column>
			<Column>
				<Text text="Click 'Value help' icon to select color"/>
			</Column>
			<Column>
				<Text text="Value from liveChange event"/>
			</Column>
		</columns>
		<ColumnListItem>
			<cells>
				<Label text='Default displayMode'/>
				<Input id="colorD"
					type="Text"
					width="200px"
					placeholder="Enter Color ..."
					showValueHelp="true"
					valueHelpRequest="openDefaultModeSample"
					change="handleInputChange"/>
			</cells>
		</ColumnListItem>
	</Table>
</mvc:View>
  • showValueHelp="true"如果需要实现点击输入框弹出某个hover的界面,这一个属性需要设置为true
  • valueHelpRequest="openDefaultModeSample"这一个属性设置的是当点击了输入框后,要执行的代码,在这个代码里面需要编写弹出拾色器的代码
  • change="handleInputChange"这一行代码是当用户在拾色器中选择完颜色后执行的代码,在这个例子中就是将拾色器中选择的颜色显示到输入框中的功能

Jscript代码如下:

sap.ui.define([
	'sap/ui/core/library',
	'sap/ui/core/mvc/Controller',
	'sap/ui/unified/ColorPickerPopover',
	'sap/ui/unified/library',
	'sap/m/MessageToast'
], function (coreLibrary, Controller, ColorPickerPopover, unifiedLibrary, MessageToast) {
	"use strict";
	var ColorPickerMode = unifiedLibrary.ColorPickerMode,
		ValueState = coreLibrary.ValueState;
	return Controller.extend("sap.ui5.walkthrough.controller.App", {
		onInit: function () {
			// the input id from which the ColorPickerPopover was opened
			this.inputId = "";
		},
		onExit: function () {
			// Destroy popovers if any
			if (this.oColorPickerPopover) {
				this.oColorPickerPopover.destroy();
			}
		},
		openDefaultModeSample: function (oEvent) {
			this.inputId = oEvent.getSource().getId();
			// 判断拾色器是否已经弹出了,如果已经弹出了,则不再重复弹出
			if (!this.oColorPickerPopover) {
				// 创建一个新的拾色器对象并设置相关的属性
				this.oColorPickerPopover = new ColorPickerPopover("oColorPickerPopover", {
					colorString: "blue",
					mode: ColorPickerMode.HSL,
					change: this.handleChange.bind(this)
				});
			}
			// 显示拾色器
			this.oColorPickerPopover.openBy(oEvent.getSource());
		},
		// 当用户在拾色器界面上点击确定后触发这个事件
		handleChange: function (oEvent) {
			var oView = this.getView(),
				oInput = oView.byId(this.inputId);
			oInput.setValue(oEvent.getParameter("colorString"));
			oInput.setValueState(ValueState.None);
			this.inputId = "";
			MessageToast.show("Chosen color string: " + oEvent.getParameter("colorString"));
		}
	});
});

3. ComboBox

需要注意ComboBox和Select组件的区别:

  • ComboBox允许用户手动的去填写内容,而Select组件用户只能通过下拉列表选择。
  • 此外,ComboBox还提供了非常强大的搜索功能和内容验证功能。
  • 通常情况下,如果没有什么特殊需求,使用Select更加方便快捷。

3.1 最简单的ComboBox

<mvc:View
	height="100%"
	controllerName="sap.m.sample.ComboBox.controller.ComboBox"
	xmlns:core="sap.ui.core"
	xmlns:mvc="sap.ui.core.mvc"
	xmlns="sap.m">
	<Page showHeader="false" class="sapUiContentPadding">
		<content>
			<ComboBox
				items="{
					path: '/CountriesCollection',
					sorter: { path: 'text' }
				}">
				<core:Item key="{key}" text="{text}" />
			</ComboBox>
		</content>
	</Page>
</mvc:View>
sap.ui.define([
		'sap/ui/core/mvc/Controller',
		'sap/ui/model/json/JSONModel'
	], function(Controller, JSONModel) {
	"use strict";

	return Controller.extend("sap.m.sample.ComboBox.controller.ComboBox", {

		onInit: function () {

			// set explored app's demo model on this sample
			var oModel = new JSONModel(sap.ui.require.toUrl("sap/ui/demo/mock/countriesExtendedCollection.json"));
			this.getView().setModel(oModel);
		}
	});
});

通过设置item属性,可以实现根据某一个属性进行排序,例如:
items="{ path: '/CountriesCollection', sorter: { path: 'text' } }"就是对text字段按照升序进行排列
如果想进行降序操作,则需要设置:
sorter: { path: 'text', descending: true}

注意ComboBox和Select的区别,ComboBox的内容键盘是可以编辑的,当然可以通过编写代码让用户只能输入

3.2 同时显示两列的ComboBox

在这里插入图片描述

只需要设置showSecondaryValues= "true"并且在每一个Item中都添加一个额外的属性additionalText = "{key}"即可

ComboBox的自动搜索功能同时也作用于双列的ComboBox

3.3 ComboBox的自动搜索功能

The default filtering is ‘starts with per term’, which filters by the beginning of every word in every column.
系统默认的搜索功能是从每一个单词的进行开头匹配。
该匹配可以作用于双列和单列ComboBox

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/725714.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【ElasticSearch】DSL查询语法

文章目录 1、DSL查询分类2、DSL基本语法3、全文检索查询4、精确查询5、地理查询6、复合查询--相关性打分算法7、复合查询之Function Score Query8、复合查询之BooleanQuery 1、DSL查询分类 Elasticsearch提供了基于JSON的DSL&#xff08;Domain Specific Language&#xff09;…

【ARM Coresight 系列文章 2 - ARM Coresight 介绍】

文章目录 1.1 ARM Coresight 介绍1.1.1 ARM Coresight 发展历史 1.2 ARM Coresight 框架介绍1.1.1 Trace 通路1.1.3 Debug 通路1.1.4 Trigger 通路 1.1 ARM Coresight 介绍 ARM Coresight是ARM公司提供的一种调试和跟踪技术&#xff0c;用于ARM处理器的调试和性能分析。它通过…

Java中规模软件开发实训——简单的文本编辑器(代码注释详解)

✨博主&#xff1a;命运之光 &#x1f338;专栏&#xff1a;Python星辰秘典 &#x1f433;专栏&#xff1a;web开发&#xff08;html css js&#xff09; ❤️专栏&#xff1a;Java经典程序设计 ☀️博主的其他文章&#xff1a;点击进入博主的主页 前言&#xff1a;在现代社会中…

k8s如何伸缩应用程序和执行滚动更新

一、伸缩应用程序 我们创建了一个 Deployment (opens new window)&#xff0c;然后通过 服务 (opens new window)提供访问 Pod 的方式。我们发布的 Deployment 只创建了一个 Pod 来运行我们的应用程序。当流量增加时&#xff0c;我们需要对应用程序进行伸缩操作以满足系统性能…

第五章:L2JMobius学习 – 快速部署L2JMobius汉化版

L2JMobius是一套开源的 LineageII 的服务器端代码&#xff0c;使用Java语言编写。在前面的章节中&#xff0c;我们安装了mariadb10数据库以及jdk17运行环境&#xff0c;这两个是必须的。紧接着&#xff0c;我们又安装了eclipse开发工具&#xff0c;然后创建了“L2J_Mobius”Jav…

按键输入实验(stm32)

目录 按键的相关代码key.ckey.h LED的相关代码BEEP的相关代码beep.cbeep.h main.c代码的相关说明相关硬件说明实验结果 说明&#xff1a;以下内容参考正点原子资料 按键的相关代码 key.c void KEY_Init(void) //IO初始化 { GPIO_InitTypeDef GPIO_InitStructure;RCC_APB2Peri…

ModaHub魔搭社区:可视化的AI原生云向量数据库 Milvus 2.2.9 :JSON、PartitionKey、Dynamic Schema

目录 新特性 功能增强 其他优化 问题修复 亮点颇多、精彩程度堪比大版本的 Milvus 2.2.9 来啦&#xff01; 随着 LLM 的持续火爆&#xff0c;众多应用开发者将目光投向了向量数据库领域&#xff0c;而作为开源向量数据库的领先者&#xff0c;Milvus 也充分吸收了大量来自社…

ROS:话题名称设置

目录 一、 前言二、rosrun设置话题重映射三、launch文件设置话题重映射四、编码设置话题名称4.1C4.1.1全局名称4.1.2相对名称4.1.3私有名称 4.2Python 实现4.2.1全局名称4.2.2相对名称4.2.3私有名称 一、 前言 在ROS中节点名称可能出现重名的情况&#xff0c;同理话题名称也可…

[攻防世界] [RE] [APK] app2

解题思路 导入jadx查看manifest.xml 查看主函数并未发现有价值的东西&#xff0c;于是查看manifest.xml中主函数下一个<activity> 截取FileDataActivity代码 package com.tencent.testvuln;import android.os.Bundle; import android.widget.TextView; import com.tence…

2022年真题 - 15 - 磁盘管理(vdo磁盘)

磁盘管理 - vdo磁盘 题目配置验证配置题目 StorageSrv - 磁盘管理 在 storagesrv 上新加一块 10G 磁盘;创建 vdo 磁盘,并开启 vdo 磁盘的重删和压缩;名字为 vdodisk,大小为150G,文件系统为 ext4;并设置开机自动挂载。挂载到 /vdodata。配置 新加一块 10G 磁盘; 安装…

驱动 作业 day4

编写LED灯的驱动&#xff0c;创建三个设备文件&#xff0c;每个设备文件和一个LED灯绑定&#xff0c;当操作这个设备文件时只能控制设备文件对应的这盏灯。 此时没有安装led2 和led3的驱动所以会打开设备文件失败 装完以后就可以正常控制了 以下是设备现象 head.h ubuntuu…

docker 的整体架构及各模块组件 《深入docker底层原理》

1.Docker 整体架构 Docker 是一个 C/S 模式的架构&#xff0c;后端是一个松耦合架构&#xff0c;模块各司其职。 1、用户是使用 Docker Client 与 Docker Daemon 建立通信&#xff0c;并发送请求给后者。 2、Docker Daemon 作为 Docker 架构中的主体部分&#xff0c;首先提供…

Windows如何设置自动关闭未响应的程序?Windows设置自动关闭未响应的程序方法,带图详解

Windows系统程序经常出现程序未响应现象&#xff0c;如何通过注册表使其自动关闭呢 1、首先快捷键winR唤出【运行】 输入regedit 2、确定后就打开了注册表编辑器&#xff0c;定位到【HKEY_CURREnT_UsER\Control panel\desktop】项下 3、在右侧找【AutoEndTasks】数值数据&#…

yolo.h5文件问题的解决 - 吴恩达深度学习:目标检测之YOLO算法

1.下载下载yad2k: git clone https://github.com/allanzelener/yad2k.git 这里面顺便有yad2k.py文件 2.下载yolov2.cfg https://github.com/pjreddie/darknet/tree/master/cfg 3.下载yolov2.weights http://pjreddie.com/media/files/yolo.weights 需要这三个文件 自己去githup…

易模为真人3D手办制作带来了创新

3d打印技术是一项近年来迅速发展的先进制造技术&#xff0c;逐渐在各个领域展现出无限的潜力。其中&#xff0c;3d打印真人手办成为了一个备受关注的领域。在市面上&#xff0c;我们常常可以看到一些热门动漫角色或明星的真人3d手办&#xff0c;逼真的细节和完美的再现度让人们…

iOS上架报错:无法添加以供审核

无法提交以供审核 要开始审核流程 必须提供以下项目 您必须为要添加的 app 提供版权信息。 您在提交 app 审核时遇到的问题是因为需要提供版权信息&#xff0c;而您的 app 缺少相关的版权信息。以下是解决此问题的步骤&#xff1a; 确认您是否拥有 app 的版权&#xff1a;在提…

mac苹果电脑,怎么把mkv转换mp4格式

mac苹果电脑&#xff0c;怎么把mkv转换mp4格式&#xff1f;如果你是一名mac苹果电脑的用户&#xff0c;在电脑上下载到mkv格式的视频后会发现它使用起来非常的麻烦&#xff0c;甚至不能直接打开播放。mkv其实也是一种时间比较久远的视频文件格式&#xff0c;但是不知道是什么原…

eNSP-OSPF组播拓展

OSPF组播拓展 文章目录 OSPF组播拓展一、拓扑结构二、基础配置三、测试验证 启动 OSPF 协议后 &#xff0c; OSPF 将向本地所有运行 OSPF 协议的接口以组播224.0.0.5的形式发送hello报 文 &#xff1b; hello 报文中将携带本地 RID 值 &#xff0c; 以及本地已知的邻居的RID值&…

nginx反向代理 404 问题

发现我们设置了反向代理没有起作用&#xff0c;最后发现原来是伪静态惹得祸 解决nginx添加反向代理代码不生效-与原rewrite伪静态规则冲突了 以thinkphp官方给的伪静态为例 if (!-e $request_filename){rewrite ^(.*)$ /index.php?s$1 last; break;}仔细研究发现发现问…

Android OpenGL ES 学习(十三) -离屏渲染FBO(截图)RBO, OES转 FBO

Android OpenGL ES 学习(一) – 基本概念 Android OpenGL ES 学习(二) – 图形渲染管线和GLSL Android OpenGL ES 学习(三) – 绘制平面图形 Android OpenGL ES 学习(四) – 正交投屏 Android OpenGL ES 学习(五) – 渐变色 Android OpenGL ES 学习(六) – 使用 VBO、VAO 和 EB…