91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

angularJS中ng-bind-html指令的示例分析

發布時間:2021-06-07 10:42:20 來源:億速云 閱讀:117 作者:小新 欄目:web開發

小編給大家分享一下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 style="color:red;font-size=18px;"></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標簽的自動轉義。

以上是“angularJS中ng-bind-html指令的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

汪清县| 祁门县| 陇南市| 阿城市| 兴文县| 通城县| 忻州市| 柯坪县| 桐梓县| 安远县| 江山市| 连平县| 长白| 彭阳县| 静宁县| 杨浦区| 克拉玛依市| 哈密市| 龙岩市| 赤壁市| 柳江县| 陇南市| 江安县| 江山市| 玉龙| 射阳县| 竹山县| 紫阳县| 兴隆县| 天津市| 长子县| 花莲市| 大名县| 红原县| 南陵县| 慈溪市| 长宁县| 高唐县| 辽阳县| 林甸县| 韶山市|