Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
4.1k views
in Technique[技术] by (71.8m points)

类似Grammarly的文本纠错功能的前端实现方法

问题描述

在使用Vue实现一个纠错功能页,需求是展示一段文本,同时根据一个错误词列表(包含错误词位置、错误词替换建议等,从后端API获取)展示其中有错误的词语。

我已经有了自己的一部分实现,但是觉得存在一些问题,希望能得到大家的建议

希望达到的效果是:

  1. 左侧展示原文,令这些错误词在原文中突出显示(如下划线)
  2. 右侧展示错误词列表
  3. 点击原文中的错误词能展开右侧的表项
  4. 点击右侧表项能高亮原文中的对应词

类似效果图如下(以Grammaly为参照)
效果图

尝试过的方法

目前实现需求1.的办法是,利用v-html展示一段parse过的内容,该内容在获取的原文的基础上(即:是一个依赖于原文的computed属性),在需要突出显示的词语两侧插入一个<span class="highlight">标签

但是该方法可能有以下问题,所以希望知道大家有没有更推荐的解决方案

  1. Vue明确指出不要使用v-html以避免XSS攻击,但我不清楚如何不用v-html实现上述需求(动态根据错误词改变原文展示的样式)
  2. parse原文并插入标签的办法完全基于字符串拼接,但感觉字符串拼接很低效且容易出错

实现需求3.的方法是,在上一步中为每个<span>多插入一个唯一对应右边表项的id,捕获文本点击事件中的该id以找到右侧表项并展开之

实现需求4.的方法是,根据上述id找到parse过的原文的该标签,在这个标签两侧再插入一对<span class="selected">标签以高亮之

有没有更加优雅的实现高亮选中词语的方法呢?
有没有更好的实现文中词语于右侧表项对应的方法呢?

涉及的代码主要是字符串拼接,因此就不放了,先行感谢各位的解答!


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)
等待大神解答

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...