亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

angularjs實(shí)現(xiàn)搜索的關(guān)鍵字在正文中高亮出來(lái)

 更新時(shí)間:2017年06月13日 10:43:33   作者:灰太大  
這篇文章主要介紹了angularjs實(shí)現(xiàn)搜索的關(guān)鍵字在正文中高亮出來(lái),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

1、定義高亮 filter

我們希望搜索的關(guān)鍵字在正文中高亮出來(lái),正文內(nèi)容就是過(guò)濾器的第一個(gè)參數(shù),第二個(gè)參數(shù)就是搜索關(guān)鍵字,這樣,我們的過(guò)濾器將會(huì)有兩個(gè)參數(shù)了。

高亮的原理很簡(jiǎn)單,將需要高亮的內(nèi)容使用 span 標(biāo)記隔離出來(lái),再加上一個(gè)高亮的 class樣式 進(jìn)行描述就可以了。

app.filter("highlight", function($sce, $log){
  var fn = function(text, search){
    $log.info("text: " + text);
    $log.info("search: " + search);
    if (!search) {
      return $sce.trustAsHtml(text);
    }
    text = encodeURIComponent(text);
    search = encodeURIComponent(search);
    var regex = new RegExp(search, 'gi')
    var result = text.replace(regex, '<span class="highlightedTextStyle">$&</span>');
    result = decodeURIComponent(result);
    $log.info("result: " + result );
    return $sce.trustAsHtml(result);
  };
  return fn;
});

$sce, 和 $log 是 angular 提供的兩個(gè)服務(wù),其中 $sce 服務(wù)需要使用 ngSanitize 模塊。關(guān)于這個(gè)模塊,可以參考:angular-ngSanitize模塊-$sanitize服務(wù)詳解

2、定義html視圖

<div ng-controller="search">
      <div>
        <input type="text" ng-model="notify.search" value=""/>
      </div>
      <!--text內(nèi)容會(huì)高亮顯示搜索關(guān)鍵字-->
      <div ng-bind-html="text | highlight:notify.search">
      </div>
</div>

3、控制器

app.controller("search", function($scope){
  $scope.text = "hello, world. hello, world. hello, world. this is filter example.";
  $scope.notify.search = "";
})

注意在控制器中引入過(guò)濾器highlight

當(dāng)搜索的關(guān)鍵字為數(shù)字時(shí),如"1",報(bào)如下錯(cuò)誤:(輸入漢字時(shí)沒(méi)有問(wèn)題)


一些解決辦法:

1.直接try catch處理,這樣太簡(jiǎn)單了,并且會(huì)導(dǎo)致新的問(wèn)題出現(xiàn)

2.把escape全部改成encodeURIComponent編碼,試了一下不能解決問(wèn)題

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 深入學(xué)習(xí)AngularJS中數(shù)據(jù)的雙向綁定機(jī)制

    深入學(xué)習(xí)AngularJS中數(shù)據(jù)的雙向綁定機(jī)制

    這篇文章主要介紹了AngularJS中數(shù)據(jù)的雙向綁定機(jī)制,雙向綁定使得HTML中呈現(xiàn)的view與AngularJS中的數(shù)據(jù)一致,是Angular的重要特性之一,需要的朋友可以參考下
    2016-03-03
  • AngularJs自定義服務(wù)之實(shí)現(xiàn)簽名和加密

    AngularJs自定義服務(wù)之實(shí)現(xiàn)簽名和加密

    AngularJS 是一個(gè) JavaScript 框架,它可以通過(guò) <script> 標(biāo)簽添加到 HTML 頁(yè)面。這篇文章主要介紹了AngularJs自定義服務(wù)之實(shí)現(xiàn)簽名和加密的相關(guān)資料,需要的朋友可以參考下
    2016-08-08
  • AngularJS Bootstrap詳細(xì)介紹及實(shí)例代碼

    AngularJS Bootstrap詳細(xì)介紹及實(shí)例代碼

    本文主要介紹AngularJS Bootstrap,這兩對(duì)AngularJS Bootstrap的基礎(chǔ)知識(shí)做了詳細(xì)講解,并提供簡(jiǎn)單示例,有需要的小伙伴可以參考下
    2016-07-07
  • 詳細(xì)介紹RxJS在Angular中的應(yīng)用

    詳細(xì)介紹RxJS在Angular中的應(yīng)用

    本篇文章主要介紹了詳細(xì)介紹RxJS在Angular中的應(yīng)用,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-09-09
  • 深入探究AngularJs之$scope對(duì)象(作用域)

    深入探究AngularJs之$scope對(duì)象(作用域)

    本篇文章主要介紹了深入探究AngularJs之$scope對(duì)象(作用域),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • AngularJS監(jiān)聽(tīng)路由的變化示例代碼

    AngularJS監(jiān)聽(tīng)路由的變化示例代碼

    這篇文章給大家分享了如何利用AngularJS監(jiān)聽(tīng)路由的變化,文中給出了示例代碼相信對(duì)大家的理解很有幫助,有需要的朋友們可以參考借鑒。
    2016-09-09
  • 詳解AngularJS中自定義過(guò)濾器

    詳解AngularJS中自定義過(guò)濾器

    過(guò)濾器(filter)正如其名,作用就是接收一個(gè)輸入,通過(guò)某個(gè)規(guī)則進(jìn)行處理,然后返回處理后的結(jié)果。主要用在數(shù)據(jù)的格式化上,例如獲取一個(gè)數(shù)組中的子集,對(duì)數(shù)組中的元素進(jìn)行排序等
    2015-12-12
  • AngularJS的Filter的示例詳解

    AngularJS的Filter的示例詳解

    本文通過(guò)示例給大家詳解angularjs 的filter知識(shí),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧
    2017-03-03
  • Angular設(shè)計(jì)模式hierarchical?injector實(shí)現(xiàn)代碼復(fù)用模塊化

    Angular設(shè)計(jì)模式hierarchical?injector實(shí)現(xiàn)代碼復(fù)用模塊化

    這篇文章主要為大家介紹了Angular設(shè)計(jì)模式hierarchical?injector實(shí)現(xiàn)代碼復(fù)用模塊化示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • AngularJS Ajax詳解及示例代碼

    AngularJS Ajax詳解及示例代碼

    本文主要講解AngularJS Ajax的知識(shí),這里提供詳細(xì)資料及代碼示例,幫助學(xué)習(xí)AngularJS的朋友,有需要的小伙伴可以參考下
    2016-08-08

最新評(píng)論