1龟劲、定義高亮 filter
我們希望搜索的關(guān)鍵字在正文中高亮出來,正文內(nèi)容就是過濾器的第一個參數(shù)阻肿,第二個參數(shù)就是搜索關(guān)鍵字,這樣沮尿,我們的過濾器將會有兩個參數(shù)了丛塌。
高亮的原理很簡單,將需要高亮的內(nèi)容使用 span 標記隔離出來畜疾,再加上一個高亮的 class樣式 進行描述就可以了赴邻。
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 提供的兩個服務(wù),其中 $sce 服務(wù)需要使用 ngSanitize 模塊啡捶。關(guān)于這個模塊姥敛,可以參考:angular-ngSanitize模塊-$sanitize服務(wù)詳解
2、定義html視圖
<div ng-controller="search">
<div>
<input type="text" ng-model="notify.search" value=""/>
</div>
<!--text內(nèi)容會高亮顯示搜索關(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 = "";
})
注意在控制器中引入過濾器highlight
當搜索的關(guān)鍵字為數(shù)字時彤敛,如"1"与帆,報如下錯誤:(輸入漢字時沒有問題)
QQ截圖20170612154133.png
一些解決辦法:
1.直接try catch處理,這樣太簡單了墨榄,并且會導致新的問題出現(xiàn)
2.把escape全部改成encodeURIComponent編碼玄糟,試了一下不能解決問題