怎么查询网站其他域名/搜狗推广管家

怎么查询网站其他域名,搜狗推广管家,注册城乡规划师教材,wordpress报表往期推文全新看点(文中附带全新鸿蒙5.0全栈学习笔录) ✏️ 鸿蒙(HarmonyOS)北向开发知识点记录~ ✏️ 鸿蒙(OpenHarmony)南向开发保姆级知识点汇总~ ✏️ 鸿蒙应用开发与鸿蒙系统开发哪个更有前景&#…

往期推文全新看点(文中附带全新鸿蒙5.0全栈学习笔录)

✏️ 鸿蒙(HarmonyOS)北向开发知识点记录~

✏️ 鸿蒙(OpenHarmony)南向开发保姆级知识点汇总~

✏️ 鸿蒙应用开发与鸿蒙系统开发哪个更有前景?

✏️ 嵌入式开发适不适合做鸿蒙南向开发?看完这篇你就了解了~

✏️ 对于大前端开发来说,转鸿蒙开发究竟是福还是祸?

✏️ 鸿蒙岗位需求突增!移动端、PC端、IoT到底该怎么选?

✏️ 记录一场鸿蒙开发岗位面试经历~

✏️ 持续更新中……


场景描述

RichEditor是支持图文混排和文本交互式编辑的组件,在我们使用的APP中是很常见的,比如评论区编辑内容发布、对话框或者聊天室。下面列举一些遇到的场景需求:

  • 场景一:基于文字图片以及@信息的好友评论
  • 场景二:右下角的剩余字数
  • 场景三:评论中携带所@的用户的附属信息
  • 场景四:文本选择区域发生变化或编辑状态下光标位置发生变化回调
  • 场景五:自由切换系统键盘和自定义键盘。

方案描述

场景一:基于文字图片以及@信息的好友评论

效果图

方案

1、通过addTextSpan来添加文字,2、通过addImageSpan来添加图片3、通过addBuilderSpan来实现一段内容光标不可插入的效果4、addTextSpan等支持gesture等手势操作,比如onClick点击和onLongPress长按事件

核心代码

1、由于RichEditor是支持图文混排的,所以RichEditor里面的内容也就是由Text和Image组成的,分别通过addTextSpan和addImageSpan添加,而且还可以设置字体和图片样式,如下代码1:

@Entry@Componentstruct getSpans {editorController = new RichEditorController()build() {Column() {RichEditor({ controller: this.editorController }).width('100%').backgroundColor(Color.Yellow).onReady(() => {this.editorController.addImageSpan($r("app.media.icon"),{imageStyle:{size: ["100px", "100px"]}})this.editorController.addTextSpan('男生女生向前冲',{style:{fontColor: Color.Blue,fontSize: 30}})})Button('getSpans-图片').onClick((event: ClickEvent) => {let getSpans = this.editorController.getSpans({ start: 0 })console.log('getSpans0' + JSON.stringify(getSpans[0]))// 必须进行强转才能获取文字信息或者图片信息let span0 = getSpans[0] as RichEditorTextSpanResultconsole.log('图片相关的信息: ' + JSON.stringify(span0))})Button('getSpans-文字').onClick((event: ClickEvent) => {let getSpans = this.editorController.getSpans({ start: 0 })console.log('getSpans1' + JSON.stringify(getSpans[1]))let span1 = getSpans[1] as RichEditorImageSpanResultconsole.log('文字相关的信息: ' + JSON.stringify(span1))})}}}

2、在常见的评论区艾特好友时,会将“@华为官方客服”视作一个整体,光标无法插入其中,且第一次按删除键时整体会高亮选中,第二次再按删除键才会删除。**需要注意的是,如果使用的全局@Builder,则需要配合bind(this)使用。**后续也可以通过事件阻止“即RichEditor控件ClickEvent/TouchEvent支持preventDefault”。

@Entry@Componentstruct BuilderSpan {editorController = new RichEditorController()@BuilderAt(str: string) {Stack() {Text('@' + str).fontColor(Color.Blue)}}build() {Column() {RichEditor({ controller: this.editorController }).width('100%').height(50).backgroundColor(Color.Yellow).onReady(() => {this.editorController.addBuilderSpan(() => {this.At('华为官方客服')})this.editorController.addTextSpan('!!!')})}}}

3、发微博的时候可以输入表情、超链接、文字等一起的内容

代码3:

@Componentstruct Index {@State message: string = '#超话社区#';controller: RichEditorController = new RichEditorController();@State show: boolean = false;build() {Column() {RichEditor({controller: this.controller}).height(56).width("90%").borderStyle(BorderStyle.Solid).borderColor(Color.Black).borderWidth(1).onReady(() => {})Button('输入表情').onClick((event: ClickEvent) => {this.controller.addImageSpan($r('app.media.app_icon'), {imageStyle: {size: ["80px", "80px"]}})})Button('超链接').onClick((event: ClickEvent) => {this.controller.addTextSpan(this.message, {offset: this.controller.getCaretOffset(),style:{fontColor: Color.Orange,fontSize: 16},gesture:{onClick: () => {console.log('要跳转链接了哦')},onLongPress: () => {console.log('我被长按了')}}})this.controller.setCaretOffset(this.controller.getCaretOffset() + this.message.length)})}.width('100%')}}

场景二:右下角的剩余字数

效果图

方案

使用overlay浮层,显示“0/20”字数提示符在组件的右下角。再通过aboutToIMEInput回调(输入法输入内容前),获取插入的文本偏移位置,对输入内容进行限制。

核心代码

import promptAction from '@ohos.promptAction';@Entry@Componentstruct MaxDemo {@State message: string = '蜡笔小新';controller: RichEditorController = new RichEditorController();@State getContentLength: number = 0;@State BOnSt:promptAction.ShowToastOptions = {'message': '已超出内容最大限制.'}build() {Column() {RichEditor({ controller: this.controller }).height(100).borderWidth(1).borderColor(Color.Red).width("100%").overlay(this.getContentLength + "/20", {align: Alignment.BottomEnd}).aboutToIMEInput((value: RichEditorInsertValue) => {console.log("insertOffset:" + JSON.stringify(value.insertValue)) // 插入的文本偏移位置。if (this.getContentLength < 20) {this.getContentLength = this.getContentLength + value.insertValue.lengthconsole.log('实时的内容长度:' + this.getContentLength)return true}promptAction.showToast(this.BOnSt)return false}).aboutToDelete((value: RichEditorDeleteValue) => {console.log('删除:' + JSON.stringify(value))this.getContentLength = this.getContentLength - value.lengthreturn true})}.width('100%')}}

场景三:评论中携带所@的用户的附属信息

效果图

方案

使用HashMap的set向HashMap中添加或更新一组数据,使用get方法获取指定key所对应的value。

核心代码

@Entry@Componentstruct SameNameDemo {controller: RichEditorController = new RichEditorController();@BuilderAt(str: string) {Stack() {Text('@' + str).fontColor(Color.Blue)}.onClick(() => {// 添加不同的身份信息const hashMap: HashMap<string, number> = new HashMap();hashMap.set("friend1", 123);let result = hashMap.get("friend1");console.log('result: ' + result)})}build() {Column() {RichEditor({ controller: this.controller }).height(100).borderWidth(1).borderColor(Color.Red).width("100%")Button('好友1').onClick((event: ClickEvent) => {this.controller.addBuilderSpan(() => {this.At('华为官方客服')})})Button('好友2').onClick((event: ClickEvent) => {this.controller.addBuilderSpan(() => {this.At('华为官方客服')})})}.width('100%')}}

场景四:文本选择区域发生变化或编辑状态下光标位置发生变化回调

效果图

方案

使用RichEditor组件在API 12支持的新接口 onSelectionChange,在文本选择区域发生变化或编辑状态下光标位置发生变化时触发该回调。光标位置发生变化回调时,选择区域的起始位置等于终止位置(即start = end)。

核心代码

@Entry@Componentstruct Index {@State message: string = '蜡笔小新';controller: RichEditorController = new RichEditorController();@State show: boolean = false;build() {Column() {RichEditor({controller: this.controller}).defaultFocus(true).padding(0).height(56).width("90%").borderStyle(BorderStyle.Solid).borderColor(Color.Black).borderWidth(1).padding({left: 10}).onReady(() => {this.controller.addTextSpan(this.message, {offset: this.controller.getCaretOffset(),style:{fontColor: Color.Orange,fontSize: 16}})this.controller.setCaretOffset(this.controller.getCaretOffset() + this.message.length)}).onSelectionChange((value:RichEditorRange) => {console.log('光标位置改变了')console.log('start: ' + value.start)console.log('end: ' + value.end)})}.width('100%')}}

场景五:自由切换系统键盘和自定义键盘

效果图

方案

使用RichEditor的属性customKeyboard控制切换系统键盘还是自定义键盘,添加表情使用addImageSpan,删除内容使用deleteSpans,并通过获取光标所在位置进行删除。

核心代码

@Entry@Componentstruct Index {@State message: string = 'Hello World';controller = new RichEditorController()@State showKeyboard:boolean = false;private listData: (string | number | Resource)[] = [$r('app.media.img'), $r('app.media.img_1'), $r('app.media.img_2'), $r('app.media.img_3'), $r('app.media.img_4'), $r('app.media.img_5'), $r('app.media.img_6'),$r('app.media.img'), $r('app.media.img_1'), $r('app.media.img_2'), $r('app.media.img_3'), $r('app.media.img_4'), $r('app.media.img_5'), $r('app.media.img_6'),$r('app.media.img'), $r('app.media.img_1'), $r('app.media.img_2'), $r('app.media.img_3'), $r('app.media.img_4'), $r('app.media.img_5'), $r('app.media.img_6'),$r('app.media.img'), $r('app.media.img_1'), $r('app.media.img_2'), $r('app.media.img_3'), $r('app.media.img_4'), $r('app.media.img_5'), $r('app.media.img_6'),$r('app.media.img'), $r('app.media.img_1'), $r('app.media.img_2'), $r('app.media.img_3'), $r('app.media.img_4'), $r('app.media.img_5'), $r('app.media.img_6'),];// 自定义键盘组件@Builder CustomKeyboardBuilder() {Column() {Text('自定义表情键盘').fontSize(25).fontWeight(900)Grid() {ForEach(this.listData, (item: string | number | Resource) => {GridItem() {if (typeof item !== 'number' && typeof item !== 'string') {Image(item).width(30).onClick(() => {this.controller.addImageSpan(item, { imageStyle: { size: ['110px', '110px'] } })})}}})}.columnsGap(10).rowsGap(10).padding(5)Row() {Image($r('app.media.img_7')).width(30).onClick(() => {this.controller.deleteSpans({start: this.controller.getCaretOffset() - 1, end: this.controller.getCaretOffset()})})}.width('100%').justifyContent(FlexAlign.End).margin({ bottom: 40 })}.borderColor(Color.Gray).borderWidth(5)}build() {Column() {RichEditor({ controller: this.controller }).width('100%').borderWidth(1).borderColor(Color.Black).onReady(() => {this.controller.addTextSpan('有序排队')}).customKeyboard(this.showKeyboard ? this.CustomKeyboardBuilder() : undefined)Button('切换系统键盘与自定义键盘').onClick((event: ClickEvent) => {this.showKeyboard = ! this.showKeyboard})}.height('100%')}}

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

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

相关文章

RIP-AV:使用上下文感知网络进行视网膜动脉/静脉分割的联合代表性实例预训练

文章目录 RIP-AV: Joint Representative Instance Pre-training with Context Aware Network for Retinal Artery/Vein Segmentation摘要方法实验结果 RIP-AV: Joint Representative Instance Pre-training with Context Aware Network for Retinal Artery/Vein Segmentation …

单片机总结【GPIO/TIM/IIC/SPI/UART】

一、GPIO 1、概念 通用输入输出口&#xff1b;开发者可以根据自己的需求将其配置为输入或输出模式&#xff0c;以实现与外部设备进行数据交互、控制外部设备等功能。简单来说&#xff0c;GPIO 就像是计算机或微控制器与外部世界沟通的 “桥梁”。 2、工作模式 工作模式性质特…

.gitignore 文件中添加忽略 .pdb 文件

我在项目的根目录下创建.gitignore文件。打开.gitignore文件并添加忽略.pdb文件的规则。如下&#xff1a; 已经在 .gitignore 文件中添加了忽略 .pdb 文件的规则&#xff0c;但是提交到 Git 仓库时仍然看到了 .pdb 文件&#xff0c;这通常意味着 .pdb 文件在 .gitignore 文件被…

半导体晶圆精控:ethercat转profient网关数据提升制造精度

数据采集系统通过网关连接离子注入机&#xff0c;精细控制半导体晶圆制造过程中的关键参数。 在半导体制造中&#xff0c;晶圆制造设备的精密控制是决定产品性能的关键因素。某半导体工厂采用耐达讯Profinet转EtherCAT协议网关NY-PN-ECATM&#xff0c;将其数据采集系统与离子注…

VSCode+PlatformIO报错 找不到头文件

如图示&#xff0c;找不到目标头文件 demo工程运行正常&#xff0c;考虑在src文件夹内开辟自己的代码&#xff0c;添加后没有找到 找了些资料&#xff0c;大概记录如下&#xff1a; 1、c_cpp_properties.json 内记录 头文件配置 .vscode 中&#xff0c;此文件是自动生成的&a…

ARM 处理器平台 eMMC Flash 存储磨损测试示例

By Toradex秦海 1). 简介 目前工业嵌入式 ARM 平台最常用的存储器件就是 eMMC Nand Flash 存储&#xff0c;而由于工业设备一般生命周期都比较长&#xff0c;eMMC 存储器件的磨损寿命对于整个设备来说至关重要&#xff0c;因此本文就基于 NXP i.MX8M Mini ARM 处理器平台演示…

uniapp 本地数据库多端适配实例(根据运行环境自动选择适配器)

项目有个需求&#xff0c;需要生成app和小程序&#xff0c;app支持离线数据库&#xff0c;如果当前没有网络提醒用户开启离线模式&#xff0c;所以就随便搞了下&#xff0c;具体的思路就是&#xff1a; 一个接口和多个实现类&#xff08;类似后端的模板设计模式&#xff09;&am…

AI探索笔记:浅谈人工智能算法分类

人工智能算法分类 这是一张经典的图片&#xff0c;基本概况了人工智能算法的现状。这张图片通过三个同心圆展示了人工智能、机器学习和深度学习之间的包含关系&#xff0c;其中人工智能是最广泛的范畴&#xff0c;机器学习是其子集&#xff0c;专注于数据驱动的算法改进&#…

进程概念、PCB及进程查看

文章目录 一.进程的概念进程控制块&#xff08;PCB&#xff09; 二.进程查看通过指令查看进程通过proc目录查看进程的cwd和exe获取进程pid和ppid通过fork()创建子进程 一.进程的概念 进程是一个运行起来的程序&#xff0c;而程序是存放在磁盘的&#xff0c;cpu要想执行程序的指…

怎么修改node_modules里的文件,怎么使用patch-package修改node_modules的文件,怎么修改第三方库原文件。

在开发中会遇到需要node_modules里第三方库有bug&#xff0c;然后需要修改node_modules文件的情况 使用patch-package包可以修改node_modules里的文件 patch-package npm 官网&#xff1a;patch-package - npm 安装 npm i patch-package 修改文件后 npx patch-package s…

seacmsv9报错注入

1、seacms的介绍 ​ seacms中文名&#xff1a;海洋影视管理系统。是一个采用了php5mysql架构的影视网站框架&#xff0c;因此&#xff0c;如果该框架有漏洞&#xff0c;那使用了该框架的各个网站都会有相同问题。 2、源码的分析 漏洞的部分源码如下&#xff1a; <?php …

Hbase客户端API——语句大全

目录 创建表&#xff1a; 插入数据&#xff1a; 删除数据&#xff1a; 修改数据&#xff1a; 查询数据&#xff1a;Get 查询数据&#xff1a;Scan 查询数据&#xff1a;过滤查询 创建表&#xff1a; 检验&#xff1a; 插入数据&#xff1a; 验证 一次多条数据插入 验证&…

IP------PPP协议

这只是IP的其中一块内容PPP&#xff0c;IP还有更多内容可以查看IP专栏&#xff0c;前一章内容为网络类型&#xff0c;可通过以下路径查看IP---网络类型-CSDN博客&#xff0c;欢迎指正 3.PPP协议 1.PPP优点 网络类型&#xff1a;p2p PPP---点到点协议 兼容性会更强凡是接口或…

Springboot基础篇(3):Bean管理

前言&#xff1a;Spring 通过扫描类路径&#xff08;Classpath&#xff09;来查找带有特定注解&#xff08;如 Component、Service、Repository 等&#xff09;的类&#xff0c;并将它们注册为 Spring 容器中的 Bean。 1 Bean扫描 Bean 扫描是 Spring 框架的核心功能之一&…

Metal 学习笔记二:3D模型

是什么让一个好游戏更好玩&#xff1f;漂亮的图像&#xff01;就像《神界&#xff1a;原罪2》&#xff0c;《暗黑破坏神3》以及《巫师3》等大作一样&#xff0c;需要一个强大的程序团队以及3D美术团队强强合作。你在屏幕中看到正是3D模型使用自定义渲染绘制的结果。就像上一章你…

数据结构与算法-图论-最短路-拓展运用

选择最佳路线 分析&#xff1a; 这是一道图论中的最短路径问题&#xff0c;目标是在给定的公交网络中&#xff0c;找到从琪琪家附近的车站出发&#xff0c;到她朋友家附近车站&#xff08;编号为 s &#xff09;的最短时间。以下是对该问题的详细分析&#xff1a; 问题关键信息…

【江科协-STM32】5. 输出比较

1. 输出比较简介 OC(Output Compare)输出比较。 输出比较可以通过CNT&#xff08;CNT计数器&#xff09;与CCR寄存器值的关系&#xff0c;来对输出电平进行置1、置0或翻转的操作&#xff0c;用于输出一定频率和占空比的PWM波形。 :::tip CNT计数器是正向计数器。它只能正向累…

C++ Primer 再探迭代器

欢迎阅读我的 【CPrimer】专栏 专栏简介&#xff1a;本专栏主要面向C初学者&#xff0c;解释C的一些基本概念和基础语言特性&#xff0c;涉及C标准库的用法&#xff0c;面向对象特性&#xff0c;泛型特性高级用法。通过使用标准库中定义的抽象设施&#xff0c;使你更加适应高级…

影响板材的热导率有哪些因素?

板材热导率受多种因素左右&#xff0c;可划分为内部材料特性与外部环境条件两大方面 内部材料特性 化学构成&#xff1a;不同化学元素及化合物组合形成的板材&#xff0c;热导率表现大相径庭&#xff1b;金属板材&#xff0c;像铜与铝&#xff0c;热导率优异&#xff0c;这是…

给字符串加密解密

加密规则&#xff1a;输入1a2b3c 输出 abbccc 解密&#xff1a;输入abbccc 输出 1a2b3c 代码&#xff1a; using System;namespace 加密解密 {class Program{static void Main(string[] args){Encryption("4b2a8p");Decryption("ppppppoovvv");Console.…