当前位置:   article > 正文

基于measure实现的文本测量_measuretextsize 异步计算

measuretextsize 异步计算

场景描述

场景一:当文本的内容超过指定的行数时显示 ...展开,当所有文本展开后,最后面跟着收起。

场景二:搜索框展示历史记录,单个子组件超过固定长度后展示省略号,固定只展示两行,超出的文字被截断,通过点击按钮展示后续文本内容

方案描述

场景一:

当文本的内容超过指定的行数时显示 ...展开,当所有文本展开后,最后面跟着收起

效果图

方案

1、文本默认超过两行时,直接截断,在截断文本后添加...展开

 2、测量两行文本和全部文本的高度,当全部文本的高度超过两行文本的高度时进行展开的逻辑

 3、文本全部展开后,点击收起,所有文本全部收齐变成固定的两行

核心代码

文本收起态(即展开逻辑)

  1. collapseText(): void {
  2.   //判断文本是否需要展开
  3.   if (!this.needProcess) {
  4.     return;
  5.   }
  6.   let titleSize : SizeOptions = measure.measureTextSize({
  7.     textContent: this.rawTitle,
  8.     constraintWidth: this.titleWidth,
  9.     fontSize: 20
  10.   })
  11.   //测量最大行数(两行)限制的高度,
  12.   let twoLineSize : SizeOptions = measure.measureTextSize({
  13.     textContent: this.rawTitle,
  14.     constraintWidth: this.titleWidth,
  15.     fontSize: 20,
  16.     maxLines: this.MAX_LINES
  17.   })
  18.   //文本未超过限制行数,不进行展开、收起处理
  19.   if (Number(titleSize.height) == Number(twoLineSize.height)) {
  20.     this.needProcess = false;
  21.     return;
  22.   }
  23.  
  24.   console.log('test row height:' + titleSize.height)
  25.   console.log('test twoLineSize height:' + twoLineSize.height)
  26.   //clipTitle被截取的文本,rawtitle只全部的文本
  27.   let clipTitle: string = this.rawTitle
  28.   //EXPAND_STR将展开这个文本赋值给最后一个span
  29.   this.lastSpan = this.EXPAND_STR;
  30.   while (Number(titleSize.height) > Number(twoLineSize.height)) {
  31.     //判断是否展开
  32.     this.expanded = true;
  33.     clipTitle = clipTitle.substring(0, clipTitle.length - 1);
  34.     titleSize = measure.measureTextSize({
  35.       //文本总共被分成三段,展示的则是被截取的文本+省略号+最后的展开或收起的文字
  36.       textContent: clipTitle + this.ellipsis + this.lastSpan,
  37.       constraintWidth: this.titleWidth,
  38.       fontSize: 20
  39.     })
  40.     console.log("test while clipTitle:" + clipTitle)
  41.     console.log("test while clipTitle height:" + titleSize.height)
  42.   }
  43.   console.log("test clipTitle:" + clipTitle)
  44.   this.title = clipTitle + this.ellipsis
  45.   this.expanded = false;
  46. }
  47. // 文本展开态(即收起逻辑)
  48. expandText(): void {
  49.   console.log('testTag: ' + this.needProcess);
  50.   if (this.needProcess) {
  51.   //文本已经展开了,就需要将最后一个文本替换成收起的样式
  52.   this.lastSpan = this.COLLAPSE_STR;
  53.   this.expanded = true;
  54.   this.title = this.rawTitle;
  55.   }
  56. }

场景二:

搜索框展示历史记录,单个子组件超过固定长度后展示省略号,固定只展示两行,超出的文字被截断,通过点击按钮展示后续文本内容

效果图

方案

1.历史记录固定只展示两行,超出的均被截断

 2.单个文本有固定尺寸,超长后会展示省略号

 3.通过点击按钮可以展示出所有的历史记录

核心代码

获取屏幕的宽度

  1. //子组件的最大宽度,目前是定死的
  2. const childMaxWidth:number = 325 //为了方便后续计算,这里的宽度数值为px
  3. let displayClass: display.Display | null = null;
  4. let componentWidth:number = 0;
  5. try {
  6.   //获取屏幕宽度
  7.   displayClass = display.getDefaultDisplaySync();
  8.   componentWidth = displayClass.width
  9.   console.log('---这是componentWidth',componentWidth)
  10. } catch (exception) {
  11.   console.error('Failed to obtain the default display object. Code: ' + JSON.stringify(exception));
  12. }
  13. // 监听下标和单个文字的改变
  14. IndexChange(){
  15.   if(this.AllWidth >= (this.restrictWidth - childMaxWidth) && this.AllWidth <= (this.restrictWidth)){
  16.     this.newIndex = this.index
  17.     console.log('---这是newIndex',this.newIndex)
  18.   }
  19. }
  20.  
  21. textChange(){
  22.   let content:string = this.message
  23.   this.textWidth = measure.measureText({
  24.     textContent: content,
  25.     fontSize: this.fontSizeData
  26.   })
  27.   if(this.textWidth > childMaxWidth){
  28.     this.AllWidth += childMaxWidth
  29.     console.log('---这是AllWidth1',this.AllWidth)
  30.  
  31.   }else{
  32.     this.AllWidth += this.textWidth
  33.     console.log('---这是AllWidth2',this.AllWidth)
  34.     console.log('---textWidth',this.textWidth)
  35.   }
  36. }
  37. // 对超出的文本进行判断
  38. aboutToAppear(): void {
  39.   // this.process();
  40.   if(componentWidth != 0){
  41.     this.restrictWidth =  Math.floor((parseFloat(this.FlexWidth) * componentWidth) * 0.01 )
  42.     console.log('---这是restrictWidth',this.restrictWidth)
  43.     console.log('---FlexWidth',(this.FlexWidth))
  44.   }
  45.   for(let i = 0;i < this.AllData.length;i++){
  46.     this.message = this.AllData[i]
  47.     this.index = i
  48.     console.log('---index',this.index)
  49.   }
  50.   this.SomeData = this.AllData.slice(0,this.newIndex+1)
  51.   this.ShowData = this.SomeData
  52. }

 

本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号