【问题标题】:Highlighting an html document expression in Asp.net mvc using JavaScript使用 JavaScript 在 Asp.net mvc 中突出显示 html 文档表达式
【发布时间】:2017-09-19 07:59:03
【问题描述】:

我正在尝试突出显示网络浏览器上显示的 html 文档中的特定句子。

我的控制器中有这个动作:

public ActionResult GetHtmlPage(string path)
{
    return new FilePathResult(path, "text/html");
}

我有这个 view 显示指定路径中的 html 文档。

@model TextPlagiarismWebApp.Models.ViewModels.ManageDocumentViewModel

@{
    ViewBag.Title = "ManageDocument";
}

<h2>ManageDocument</h2>

@Html.Action("GetHtmlPage", "Upload", new { path = Model.documentPath })

<script type="text/javascript">
    var sen = @Model.sentence["sentence"];
    $("div:contains('" + sen + "')").html(function (_, html) {
        var regex = new RegExp("(" + sen + ")", "g");
        return html.replace(regex, '<span style="background-color:#FFFF00">$1</span>');
    });
</script>

我调试了程序,并且 sen 变量是我所期望的:

var sen = @Model.sentence["sentence"];

但尽管如此,它并没有突出显示我正在寻找的特定句子。它只显示原始的 html 文档。

让我们以这个我确定句子存在的例子为例:

var sen = "Requirements for breeding tanks vary with each species. Separate tanks may be required."

HTML:

<p class=MsoNormal style='text-align:justify;mso-layout-grid-align:none;
text-autospace:none'><span lang=EN-AU style='color:black'>Requirements for
breeding tanks vary with each species. Separate tanks may be required.<o:p>
</o:p></span></p>

但是句子没有突出显示,我不知道为什么。

有什么建议吗?

【问题讨论】:

标签: javascript jquery html asp.net asp.net-mvc


【解决方案1】:

你可以这样做

  $("body").html(function (_, innerHTML) {
        var regex = new RegExp("(" + sen + "'))", "g");
        return innerHTML.replace(/\s\s+/g, ' ').replace(/\r?\n|\r/g, '').replace(regex, '<span style="background-color:#FFFF00">$1</span>');
    });

第一次替换将.replace(/\s\s+/g, ' ') 将删除多个空格,.replace(/\r?\n|\r/g, '') 将删除段落中的换行符

这里是示例https://jsfiddle.net/jz86v8we/10/

编辑

您可以通过添加使用Jquery-Highlight-5.js

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.0/jquery.min.js"></script>

<script src="http://johannburkard.de/resources/Johann/jquery.highlight-5.js"></script>

在脚本中使用

$("body").highlight("The Business");

并将其添加到您的 css 文件中

.highlight { background-color: yellow }

【讨论】:

  • 我有一个更大的文档,我想突出显示“The Business”
  • @NasriYatim 你应该使用这个johannburkard.de/blog/programming/javascript/…
  • @NasriYatim 我已经更新了答案并下载 jquery.highlight-5.js 文件,如果它不起作用
  • 不工作,不突出和搞砸布局
猜你喜欢
  • 2012-01-13
  • 1970-01-01
  • 1970-01-01
  • 2017-03-21
  • 2018-08-29
  • 1970-01-01
  • 1970-01-01
  • 2012-01-12
  • 1970-01-01
相关资源
最近更新 更多