angularjs中ng-bind-html的用法總結(jié)
本篇主要講解angular中的$sanitize這個服務(wù).此服務(wù)依賴于ngSanitize模塊.(這個模塊需要加載angular-sanitize.js插件)
要學(xué)習(xí)這個服務(wù),先要了解另一個指令: ng-bing-html.
顧名思義,ng-bind-html和ng-bind的區(qū)別就是,ng-bind把值作為字符串,和元素的內(nèi)容進(jìn)行綁定,但是ng-bind-html把值作為html,和元素的html進(jìn)行綁定.相當(dāng)于jq里面的.text()和.html().
但是,出于安全考慮,如果我們直接使用ng-bind-html是會報錯的,ng-bind-html后面的內(nèi)容必須經(jīng)過一定的處理.
處理的方式有兩種,一種是使用$sce服務(wù),另一種就是使用$sanitize服務(wù).$sce服務(wù)怎么用,在以后的文章中會獨(dú)立講解,這篇主要講解$sanitize服務(wù).
$sanitize會根絕一個白名單來凈化html標(biāo)簽.這樣,不安全的內(nèi)容就不會被返回. 白名單是根據(jù)$compileProvider的aHrefSanitizationWhitelist和imgSrcSanitizationWhitelist函數(shù)得到的.
看一個栗子:
html:
<!DOCTYPE html> <html ng-app="myApp"> <head> <title></title> <meta charset="utf-8"> <script src="../angular-1.3.2.js"></script> <script src="angular-sanitize.min.js"></script> <script src="script.js"></script> <link type="text/css" href="../bootstrap.css" rel="external nofollow" rel="stylesheet" /> </head> <body> <div class="container" ng-controller="ctrl"> <div ng-bind-html="trustHtml"></div> </div> </body> </html>
js:
var app =angular.module(‘myApp‘,[‘ngSanitize‘]); app.controller(‘ctrl‘,function($scope,$sce){ $scope.myHtml = ‘<p style="color:blue">an html\n‘ + ‘<em onclick="this.textContent=\‘code_bunny\‘">click here</em>\n‘ + ‘snippet</p>‘; $scope.trustHtml = $sce.trustAsHtml($scope.myHtml) });
這樣,在div內(nèi)就能加載上帶有html標(biāo)簽的內(nèi)容,標(biāo)簽的屬性以及綁定在元素上的事件都會被保留。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Angular.js實(shí)現(xiàn)多個checkbox只能選擇一個的方法示例
這篇文章主要給大家介紹了利用Angular.js實(shí)現(xiàn)多個checkbox只能選擇一個的方法,文中給出了詳細(xì)的示例代碼,相信對大家具有一定的參考價值,下面來一起看看吧。2017-02-02Angular directive遞歸實(shí)現(xiàn)目錄樹結(jié)構(gòu)代碼實(shí)例
本篇文章主要介紹了Angular directive遞歸實(shí)現(xiàn)目錄樹結(jié)構(gòu)代碼實(shí)例,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05詳解Angular組件數(shù)據(jù)不能實(shí)時更新到視圖上的問題
這篇文章主要為大家介紹了Angular組件數(shù)據(jù)不能實(shí)時更新到視圖上的問題詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10Angular 開發(fā)學(xué)習(xí)之Angular CLI的安裝使用
這篇文章主要介紹了Angular 開發(fā)學(xué)習(xí)之Angular CLI的安裝使用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-12-12Angular單元測試之事件觸發(fā)的實(shí)現(xiàn)
這篇文章主要介紹了Angular單元測試之事件觸發(fā)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01AngularJS基于factory創(chuàng)建自定義服務(wù)的方法詳解
這篇文章主要介紹了AngularJS基于factory創(chuàng)建自定義服務(wù)的方法,結(jié)合實(shí)例形式分析了AngularJS使用factory創(chuàng)建自定義服務(wù)的具體步驟、操作技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-05-05