麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > JavaScript > 正文

angularJS的ng-bind-html指令詳解

2020-03-24 19:08:55
字體:
來源:轉載
供稿:網友
這次給大家帶來angularJS的ng-bind-html指令詳解,使用angularJS的ng-bind-html指令的注意事項有哪些,下面就是實戰案例,一起來看一下。

angular js的強大之處之一就是他的數據雙向綁定這個功能,我們會常常用到的兩個東西就是ng-bind和針對form的ng-model。但在我們的項目當中會遇到這樣的情況,后臺返回的數據中帶有各種各樣的html標簽。如:

$scope.text = “hello, br b 這是一個例子 /b ”

我們用ng-bind-html這樣的指令來綁定,結果卻不是我們想要的。是這樣的:
hello,這是一個例子(我們給文字設置的b標簽樣式丟失了)

調試了半天,最后鎖定問題并解決問題。,不過辛苦還是值得的,畢竟為了弄明白這一點又學習了更多代碼。

原因是這樣的:

angularJS在進行數據綁定時默認是會以文本的形式輸出,也就是對你數據中的html標簽不進行轉義照單全收,這樣提高了安全性,防止了html標簽中的注入攻擊。但是如果我們的應用場景,是類似于文章詳情頁,從數據庫讀取帶格式的文本時,無法正常的顯示在頁面中。如下:

$scope.htmlStr = p >

這個時候我們必須要使用$sce這個服務來解決我們的問題。所謂sce即“Strict Contextual Escaping”的縮寫。翻譯成中文就是“嚴格的上下文模式”也可以理解為安全綁定吧。該方法將值轉換為特權所接受并能安全地使用“ng-bind-html”來綁定。
來看看如何使用吧:

把它封裝成一個過濾器就可以在模板上隨時調用了

//注冊一個過濾器,掛載到任意一個angular.module下,如果自定義過濾器較多,可以提取出來一個公用的過濾器module .filter( to_trusted , [ $sce , function ($sce) { return function (text) { return $sce.trustAsHtml(text); }]);//然后在頁面中這樣使用 p ng-bind-html= article.text | to_trusted /p 

$sce是angularJS自帶的安全處理模塊,$sce.trustAsHtml(input)方法便是將數據內容以html的形式進行解析并返回。將此過濾器添加到ng-bind-html所綁定的數據中,便實現了在數據加載時對于html標簽的自動轉義。

相信看了本文案例你已經掌握了方法,更多精彩請關注php 其它相關文章!

相關閱讀:

WEB的接口管理工具

ionic應用里文字不能長按復制、粘貼怎么辦

以上就是angularJS的ng-bind-html指令詳解的詳細內容,html教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 免费的性生活视频 | 国产精品午夜在线观看 | 久久精品一二三区 | 黄色片在线免费播放 | 国产三级精品最新在线 | 成人一级毛片 | 成人毛片100部免费观看 | 久久久久九九九女人毛片 | 一色桃子av大全在线播放 | 成人三级免费电影 | 成人三级免费电影 | 4p一女两男做爰在线观看 | 永久免费黄色片 | 在线观看免费污视频 | 欧美视频一区二区三区四区 | 久久久久久久久久久影视 | 欧美 日韩 三区 | 欧美性黄 | 免费观看三级毛片 | 精品国产专区 | h视频在线观看免费 | 久草在线视频看看 | www视频免费观看 | 欧美一级黑人 | 中文字幕亚洲情99在线 | 黄色av网站在线观看 | 亚洲成人在线免费观看 | 欧美精品一区二区三区在线 | 国产日本欧美在线观看 | 99精品视频在线观看免费播放 | 成人免费毛片片v | 香蕉成人在线视频 | 偿还电影免费看 | 午夜影视一区二区 | 久久精品一区视频 | 欧美18—19sex性hd | 日本在线播放一区二区 | 伊人网站| 成人在线观看一区二区 | 欧美成人免费一区二区三区 | 久综合|