美文网首页
flutter 比较两个字符串,不同处高亮显示

flutter 比较两个字符串,不同处高亮显示

作者: sj1910 | 来源:发表于2022-05-18 08:59 被阅读0次

    str1与str2比较,str2与str1不同处高亮显示

    class StringUtil {
      ///比较字符串,返回list['':false,'':true]
      ///false不相同部分
      ///true相同部分
      ///按返回list顺序用RichText拼接就行
      static List compare(String str1, String str2) {
        var resultList = [];
    
        ///先把字符串比较返回一个包含true或false的compareList
        var compareList = [];
        final minCount = min(str1.length, str2.length);
        for (var i = 0; i < minCount; i++) {
          final l1 = str1.codeUnitAt(i);
          final l2 = str2.codeUnitAt(i);
          if (l1 != l2) {
            compareList.add(false);
          } else {
            compareList.add(true);
          }
        }
    
        if (str1.length < str2.length) {
          for (var i = str1.length; i < str2.length; i++) {
            compareList.add(false);
          }
        }
    
        ///把字符串比较返回一个包含true或false的compareList拆分字符串,
        ///前后返回类型一致的拼接在一起,根据true或者false,组成一个map,添加到最后返回的resultList中
        var resultString = '';
    
        var str2List = str2.codeUnits;
    
        for (var j = 0; j < compareList.length; j++) {
          var string = String.fromCharCode(str2List[j]);
          if (j == 0) {
            resultString = string;
          } else {
            if (compareList[j - 1] == compareList[j]) {
              resultString = '$resultString$string';
    
              ///最后一条数据时直接加入resultList中
              if (j == compareList.length - 1) {
                resultList.add({resultString: compareList[j]});
              }
            } else {
              ///返回结果和上一个不一致时,添加到resultList中,resultString重新开始
              if (compareList[j]) {
                resultList.add({resultString: false});
              } else {
                resultList.add({resultString: true});
              }
              resultString = string;
    
              ///最后一条数据时直接加入resultList中
              if (j == compareList.length - 1) {
                resultList.add({resultString: compareList[j]});
              }
            }
          }
        }
    
        return resultList;
      }
    }
    

    使用方法

    List<TextSpan> richTextList(String str1,String str2) {
            var richList = <TextSpan>[];
            StringUtil.compare(str1, str2)
                .forEach((element) {
              if (element.values.first) {
                richList.add(TextSpan(
                  text: element.keys.first,
                  style: Color(0xFF333333),
                ));
              } else {
                richList.add(TextSpan(
                  text: element.keys.first,
                  style: Theme.of(context).colorScheme.primary,
                ));
              }
            });
            return richList;
          }
    

    相关文章

      网友评论

          本文标题:flutter 比较两个字符串,不同处高亮显示

          本文链接:https://www.haomeiwen.com/subject/miknurtx.html