今天嘗試用 Rails 做后端提供 JSON 格式的數據, AngularJS 做前端處理 JSON 數據,其中碰到 AngularJS 獲取的是一段 HTML 文本,如果直接使用 data-ng-bind 的話是被轉義過的,使用 data-ng-bind-html 則可以取消轉義。
但是直接使用 data-ng-bind-html 的話會提示錯誤
在我這里 Angular 通過 API 或取的所有文章中,每篇文章有個 html_body 屬性是經過 Markdown 或者 Org 渲染過的 HTML 片段。
在通過 API 獲取 JSON 數據后,使用 AngularJS 提供的 angular.forEach 方法對每個 post 的 html_body 進行標記,并將結果保存為 trustedBody, 然后在 HTML 中使用 data-ng-bind-html="post.trustedBody" 即可以取消轉義。
AngularJS 部分
$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();
});
新聞熱點
疑難解答
圖片精選