AngularJS中取消對HTML片段轉(zhuǎn)義的方法例子
今天嘗試用 Rails 做后端提供 JSON 格式的數(shù)據(jù), AngularJS 做前端處理 JSON 數(shù)據(jù),其中碰到 AngularJS 獲取的是一段 HTML 文本,如果直接使用 data-ng-bind 的話是被轉(zhuǎn)義過的,使用 data-ng-bind-html 則可以取消轉(zhuǎn)義。
但是直接使用 data-ng-bind-html 的話會(huì)提示錯(cuò)誤
Error: [$sce:unsafe] Attempting to use an unsafe value in a safe context.
HTML 片段需要先使用 $sce.trustAsHtml(html_in_string) 將標(biāo)記為信任,然后才可以使用 data-ng-bind-html="html_in_string" 取消轉(zhuǎn)義。
在我這里 Angular 通過 API 或取的所有文章中,每篇文章有個(gè) html_body 屬性是經(jīng)過 Markdown 或者 Org 渲染過的 HTML 片段。
在通過 API 獲取 JSON 數(shù)據(jù)后,使用 AngularJS 提供的 angular.forEach 方法對每個(gè) post 的 html_body 進(jìn)行標(biāo)記,并將結(jié)果保存為 trustedBody, 然后在 HTML 中使用 data-ng-bind-html="post.trustedBody" 即可以取消轉(zhuǎn)義。
AngularJS 部分
Blog.controller('PostsController', function ($scope, $http, $sce) {
$scope.posts = [];
$scope.syncPosts = function () {
var request = $http.get('http:/localhost:3000/posts.json');
request.success(function (response) {
$scope.posts = angular.forEach(angular.fromJson(response), function (post) {
post.trustedBody = $sce.trustAsHtml(post.html_body);
});
});
};
$scope.syncPosts();
});
HTML 部分
<div class="post-body markup-body" data-ng-bind-html="post.trustedBody"></div>
相關(guān)文章
詳解AngularJS中$filter過濾器使用(自定義過濾器)
這篇文章主要介紹了詳解AngularJS中$filter過濾器使用(自定義過濾器)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02Angular 1.x個(gè)人使用的經(jīng)驗(yàn)小結(jié)
這篇文章主要給大家介紹了關(guān)于Angular 1.x個(gè)人使用的一些經(jīng)驗(yàn),屬于一些基礎(chǔ)入門教程,文中通過示例代碼介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。2017-07-07AngularJS基礎(chǔ) ng-focus 指令簡單示例
本文主要介紹AngularJS ng-focus 指令,這里整理了ng-focus的一些基礎(chǔ)資料,并附一個(gè)實(shí)例代碼,有需要的小伙伴參考下2016-08-08Angular2中如何使用ngx-translate進(jìn)行國際化
本篇文章主要介紹了Angular2中使用ngx-translate進(jìn)行國際化,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05angularjs自定義ng-model標(biāo)簽的屬性
這篇文章主要介紹了angularjs自定義ng-model標(biāo)簽的屬性的相關(guān)資料,需要的朋友可以參考下2016-01-01AngularJS實(shí)現(xiàn)使用路由切換視圖的方法
這篇文章主要介紹了AngularJS實(shí)現(xiàn)使用路由切換視圖的方法,結(jié)合學(xué)生信息管理系統(tǒng)為例分析了使用controllers.js控制器來切換視圖的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下2017-01-01Angular應(yīng)用程序的Hydration基本概念詳解
這篇文章主要為大家介紹了Angular應(yīng)用程序的Hydration基本概念詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09AngularJS轉(zhuǎn)換響應(yīng)內(nèi)容
這篇文章主要介紹了AngularJS轉(zhuǎn)換響應(yīng)內(nèi)容 的相關(guān)資料,需要的朋友可以參考下2016-01-01AngularJS模態(tài)框模板ngDialog的使用詳解
這篇文章主要介紹了AngularJS模態(tài)框模板ngDialog的使用詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05利用CSS3在Angular中實(shí)現(xiàn)動(dòng)畫
這篇文章主要介紹了如何利用CSS3在Angular中實(shí)現(xiàn)動(dòng)畫效果,對angular動(dòng)畫相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2016-01-01