当前位置: 首页 > news >正文

徐州做外贸网站ui培训周记

徐州做外贸网站,ui培训周记,哪家公司设计网站,详情页设计收费前言 在开发微信小程序时,使用 textarea 组件可能会遇到一些棘手的问题。最近我在使用 uniapp 开发微信小程序时,就遇到了两个非常令人头疼的问题: 层级穿透:由于 textarea 是原生组件,任何元素都无法遮盖住它。当其…

前言

在开发微信小程序时,使用 textarea 组件可能会遇到一些棘手的问题。最近我在使用 uniapp 开发微信小程序时,就遇到了两个非常令人头疼的问题:

  1. 层级穿透:由于 textarea 是原生组件,任何元素都无法遮盖住它。当其他元素与 textarea 重叠时,就会出现层级穿透的问题。特别是在弹窗中使用 textarea 时,如果弹窗有动画效果,textarea 会在动画执行期间显示在页面右上角,导致视觉效果非常差。如果等到动画结束后再显示 textarea,又会出现突然弹出的效果,影响用户体验。
  2. 光标位置不正确:在 iOS 设备上,textarea 的光标默认会出现在文本的最前面。当文本较长时,点击文本中间位置时光标仍然会出现在最前面,弹出键盘后很难重新定位到需要编辑的位置,使用体验非常糟糕。

为了解决这些问题,我尝试了多种方案,但效果都不尽如人意。最终,我发现可以使用 editor 富文本编辑器组件来替代 textarea,它不仅解决了上述问题,还提供了更多的自定义选项。

封装 Editor 组件

editor 富文本编辑器组件不仅可以实现多行文本输入,还能避免层级穿透和光标位置错误的问题,甚至可以自定义光标的颜色。

官方对 editor 组件的介绍如下:

富文本编辑器,可以对图片、文字格式进行编辑和混排。

既然 editor 是一个富文本编辑器,那么它自然可以处理带有格式的文本。我们可以通过降级使用,将其作为一个普通的文本输入框,输入和输出的内容都是纯文本。

我的实现代码如下:

<template><view class="relative"><!-- 编辑器区域 --><editor:id="editorId":model-value="htmlContent"class="w-full bg-gray-50/50 rounded-xl p-3 text-sm min-h-[120px] text-base":placeholder="placeholder || '请输入内容...'"@ready="onEditorReady"@input="handleInput":read-only="isReadOnly"/></view>
</template><script setup lang="ts">
import { EditorContext } from '@/types/global'
import nanoid from '@/utils/nanoid'const props = defineProps<{modelValue: stringplaceholder?: stringid?: string
}>()const emit = defineEmits<{(e: 'update:modelValue', value: string): void(e: 'blur'): void
}>()// 编辑器内部 HTML 内容
const htmlContent = ref(props.modelValue)
// 编辑器上下文
const editorCtx = ref<EditorContext | null>(null)
const isReadOnly = ref(true)// 生成唯一 id
const editorId = computed(() => props.id || `editor-${nanoid()}`)
const instance = getCurrentInstance()// 初始化编辑器
const onEditorReady = () => {uni.createSelectorQuery().in(instance).select(`#${editorId.value}`).context((res: any) => {editorCtx.value = res.context// 只设置初始内容,不自动聚焦if (editorCtx.value && props.modelValue) {editorCtx.value.setContents({ html: props.modelValue })}isReadOnly.value = false}).exec()
}// 处理输入
const handleInput = (e: any) => {// 保存 HTML 内容htmlContent.value = e.detail.html || ''// 向外发送纯文本emit('update:modelValue', e.detail.text || '')
}defineExpose({editorCtx,
})
</script><style scoped>
:deep([id^='editor']) {caret-color: rgb(99, 102, 241);
}
</style>

如果你有需要可以直接复制使用,作为组件引入。这里面有几个注意点我介绍一下:

  1. 默认的 readonlytrue ,在编辑器准备完成后修改为 true,这个逻辑是因为 setContent 设置内容时会自动聚焦,设置为 readonly: false 就不会触发自动聚焦了,如果你需要自动聚焦可以将这段逻辑移除掉。
  2. 默认暴露了 editorCtx 如果你想主动修改编辑器内容可以触发 editorCtx.setContent 去修改,而不是直接修改 modelValue,因为内部并没有监听 modelValue 的实时变化去修改编辑器,避免多处地方同时修改编辑器内容。
  3. :deep([id^='editor']) { caret-color: rgb(99, 102, 241); }:用于修改编辑器中光标颜色,因为我这里支持自定义 id ,所以匹配了所有 editor 前缀。

通过将 textarea 替换为 editor 后,你会发现效果都是一样的,而且在 ios 端的使用体验会好很多,手指点击哪里,光标的默认位置就在哪里,在效果如下图所示。

image.png

💡注意点editor 组件在 focus 时在 ios 设备上是不会获取到键盘高度的,因此如果你有工具栏放在键盘上的需求,在替换组件时需要慎重考虑。

总结

如果你想查看 editor 组件的实际效果,可以搜索学习卡盒小程序,在卡片页面长按编辑尝试一下,看看效果是否符合你的需求。希望这篇文章能帮助你解决遇到的问题。如果对你有帮助,欢迎点赞支持!

http://www.yayakq.cn/news/666763/

相关文章:

  • 化妆品网站建设实施方案上海市小公司名称有哪些
  • 性价比最高的网站建设全媒体运营师培训费用
  • 网站建设运营公司网络营销策划书300字
  • 网站建设卖点平面设计公司哪家好
  • 岗巴网站建设网页首页设计模板图片
  • 河南平价的seo整站优化定制网络推广商城
  • 东莞百度快速排名优化宁波seo排名外包
  • 郑州网站制作招聘承接电商网站建设
  • 怎么做网站的api都江堰网站建设培训学校
  • 如何在工商局网站做企业年报虚拟产品货源渠道
  • 大人怎么做羞羞的网站泗洪有做网站
  • wordpress 网站显示加载时长网站搜索引擎优化的内容
  • 如何修改网站内容wordpress只能访问首页
  • 入侵织梦网站后台威海哪家网站做的好
  • 苏州吴中区住房和城乡建设局网站哪里有整站优化
  • 做网站和app哪个难中英文网站切换
  • 项目建设环境影响登记表在哪个网站网络推广员是什么工作
  • 深圳地区5g微波网站建设计划公司邮箱地址怎么填写
  • 家具网站建设的背景多媒体网站建设
  • 如何做学校的网站设计火锅自助餐网站建设
  • 用什么软件做网站好重庆市建设工程质量协会网站
  • 关于加强政务网站建设的通知我国档案网站建设比较分析
  • 建设一个网站需要多少钱博客为什么用wordpress
  • 网站建设电话咨询深圳网站建设手机网站建设
  • 广东旅游网站建设方案企业网站的总体设计
  • 上海集团网站制作网站优化改版
  • 如何制作手机购物网站东营有什么网站建设公司
  • 那些网站可以做行测题wordpress问答插件
  • 四川建设工程网上合同备案网站wordpress仿包图网
  • 天津 企业网站建设虚拟主机有哪些