javascript - 如何用 Javascript 中的唯一值替换文本中的不同单词?

标签 javascript string replace

我想使用 RegExp() javascript 函数将文本中的许多单词(或短语)替换为相同的值。它用正确的值替换单数单词,但是当它必须替换包含相同单词的短语时,它不起作用(不知道它是如何工作的)。

在我的文本中,例如,我想将事件每周事件分钟替换为相同的值:

"The activity patient correspond to Weekly activity minutes"

但它只是取代事件

我是如何做到的:

我有一个 keywords.js 文件,我在其中获取结构如下的对象内的所有短语:

let keywords: {
    "activity": {
        phrases: ['activity']
    },
    "sleep": {
        phrases: ['sleep']
    }
}

在我的 html 中的 javascript 部分:

@section('javascript')
    <script type="application/javascript" src="{{ asset("js/keywords.js") }}"></script>
    <script>
    $(function () {
       @if($patient)
          let patient = {
              weight: 60,
              height: 70,
              'currents' : {
                  "activity" : 100,
                  "sleep" : 60
              },
          }
          let t = $("#text-section-article").html(t); //the text where i want to look for word/phrases

          Object.entries(keywords).forEach(([key, values])=>{
          //Im iterating all over the keywords words
              Object.entries(values).forEach(([phraseKey, phraseValue])=>{
              //Im iterating all over the phrases
                  if(patient.currents.hasOwnProperty(key)){
                  //If my patient have activity in my object 'currents' I put a tooltip to that word in my body text by replacing it in this way.
                  title = `Your current ${phraseValue} is ${patient.currents[key]}`; //Your current activity is 100
                  t = t.replace(new RegExp(key, 'gi'), '<span data-toggle="tooltip" title="' + title + '" class="tip ' + phraseValue + '">' + phraseValue + '</span>');
                  }
              });       
       });
       $("#text-section-article").html(t);
       @endif
    });
    </script>
@endsection

在本例中,在我的文章文本中,所有事件单词现在都有一个工具提示,显示其当前值。

我想要做的是以这种方式添加更多单词和短语到我的关键字对象中:

let keywords: {
    "activity": {
        phrases: ['activity', 'Weekly activity minutes']
    },
    "sleep": {
        phrases: ['sleep', 'Sleep minutes']
    }
}

用相同的患者对象值替换我的文章文本中的所有这些短语(如果存在)。

我对此经历了一段糟糕的时光,如果您帮助我找到一种方法来管理我所描述的所有内容,我将非常感激,如果有一个简单/更好的方法来处理它,请告诉我。

感谢您的阅读!

最佳答案

我不确定是否可以使用正则表达式,但您可以执行下一步:

首先,您需要按照从最长到最短的顺序对短语进行排序。通过这种方式,您首先收集可能包含较短短语的所有短语。所以如果你有

['activity', 'Weekly activity']

应该变成

['Weekly activity', 'activity']

然后,您需要将原始字符串拆分为一个数组,以便可以迭代并查找短语。

['The', 'activity', 'patient', 'is', 'correspond', 'to', 'Weekly', 'activity', 'minutes']

这个想法是将原始数组转换为:

['The', 'activity', 'patient', 'is', 'correspond', 'to', 'Weekly activity minutes']

我们不再有单独的单词,而是短语。在查找这些短语时,您还应该记录在结果数组中可以找到该短语的索引。

此时,您需要做的就是迭代结果数组,检查是否记录了当前短语的索引,如果是,则用 <span> 将其包裹起来。元素,如果不是你就跳过它。最后一步是将结果中的每个短语连接成一个字符串。

这是 jsfiddle 演示:https://jsfiddle.net/tara5/43gcz0mx/

有点粗糙,可以优化短语搜索,减少迭代次数。

关于javascript - 如何用 Javascript 中的唯一值替换文本中的不同单词?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59760676/

相关文章:

javascript - 如何让 AngularJS 将我的模型属性设置为 null 而不是 <select> 中的 undefined

string - Perl $strings 到哈希表的转换

javascript - Jquery 一次点击循环两次

javascript - 我可以在 iframe 中使用 window.location.replace 吗?

javascript - 无法将数据从 Controller 绑定(bind)到 View 。控制台没有错误

arrays - 使用多字符分隔符将字符串拆分为数组

java - 错误: -Xdiag and String cannot be converted to int

Vim:用默认缓冲区替换选择而不覆盖缓冲区

xml - 通过Powershell搜索/替换XML

替换 R 中 lm() OLS 模型中的基础标准错误