一、前提
在開始本文之前先設定,從server取下來的內容是一個html格式 的內容,那么如下顯示:
<div class="article-view-content col-md-12 col-sm-12 col-xs-12 no-padding-left no-padding-right wiki" ng-bind-html="vm.article.content | ArticlesTrim"></div>
二、過濾器
現在要做的事情就是做一個過濾器就好了,讓他來去掉content里面的空行
angular .module('articles') .filter('ArticlesTrim', ArticlesTrim)ArticlesTrim.$inject = [];function ArticlesTrim() { return function (htmlContent) { var re = /<p><br//><//p>|<p><br><//p>|<p>/s<//p>/g; var trimLFCR = htmlContent.replace(re, ''); return trimLFCR; }}
這里要注意:正則表達式的編寫,我這里去掉是三種:
<p><br/></p><p><br></p><p>/s<//p>
這里regexp的寫法,其實就是/xxx/g最后的g表示全部匹配,如果用gi則表示大小寫嚴格。然后,里面/需轉義,所以:
<p><br/></p>
轉義之后是:
<p><br//><//p>
三、正則表達式其他寫法
ArticlesTrim.$inject = [];function ArticlesTrim() { return function (htmlContent) { var regex = new RegExp('<p><br/></p>', 'g'); var trimLFCR = htmlContent.replace(regex, ''); regex = new RegExp('<p><br></p>', 'g'); trimLFCR = trimLFCR.replace(regex, ''); return trimLFCR; }}
每一種需要處理的情況,就做一個RegExp來完成。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對武林網的支持。
新聞熱點
疑難解答