AngularJS中取消对HTML片段转义的方法例子
2015-01-04 00:00
1586 查看
今天尝试用 Rails 做后端提供 JSON 格式的数据, AngularJS 做前端处理 JSON 数据,其中碰到 AngularJS 获取的是一段 HTML 文本,如果直接使用 data-ng-bind 的话是被转义过的,使用 data-ng-bind-html 则可以取消转义。
但是直接使用 data-ng-bind-html 的话会提示错误
HTML 片段需要先使用 $sce.trustAsHtml(html_in_string) 将标记为信任,然后才可以使用 data-ng-bind-html="html_in_string" 取消转义。
在我这里 Angular 通过 API 或取的所有文章中,每篇文章有个 html_body 属性是经过 Markdown 或者 Org 渲染过的 HTML 片段。
在通过 API 获取 JSON 数据后,使用 AngularJS 提供的 angular.forEach 方法对每个 post 的 html_body 进行标记,并将结果保存为 trustedBody, 然后在 HTML 中使用 data-ng-bind-html="post.trustedBody" 即可以取消转义。
AngularJS 部分
HTML 部分
但是直接使用 data-ng-bind-html 的话会提示错误
Error: [$sce:unsafe] Attempting to use an unsafe value in a safe context.
HTML 片段需要先使用 $sce.trustAsHtml(html_in_string) 将标记为信任,然后才可以使用 data-ng-bind-html="html_in_string" 取消转义。
在我这里 Angular 通过 API 或取的所有文章中,每篇文章有个 html_body 属性是经过 Markdown 或者 Org 渲染过的 HTML 片段。
在通过 API 获取 JSON 数据后,使用 AngularJS 提供的 angular.forEach 方法对每个 post 的 html_body 进行标记,并将结果保存为 trustedBody, 然后在 HTML 中使用 data-ng-bind-html="post.trustedBody" 即可以取消转义。
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>
相关文章推荐
- AngularJS中取消对HTML片段转义的方法例子
- 【转】AngularJS 取消对 HTML 片段的转义
- AngularJS取消对HTML转义
- AngularJs 取消对 html 字符串标签转义
- JavaScript 的HTML转义方法 html_encode 和 html_decode
- .net mvc3.0中带html标签的值显示在页面中不被转义的方法
- 重载 CreateParams 方法[1]: 从一个例子开始(取消窗口最大化、最小化按钮的三种方法)
- 一个简单的方法,对HTML的字符进行转义
- java防SQL注入html编码入侵特殊字符转义和方法入参检测工具(Spring) ---转载
- java 防SQL注入 html编码入侵 特殊字符转义 方法入参检测工具 (Spring)
- java防SQL注入html编码入侵特殊字符转义和方法入参检测工具(Spring)
- Struts2下进行html转义的方法(解决页面输出html标签问题)
- HtmlTableRowCollection.GetEnumerator 方法的C#例子
- 使用AngularJS来实现HTML页面嵌套的方法
- 使用AngularJS来实现HTML页面嵌套的方法
- HTML传递参数的方法和例子
- Playframework中HTML转义方法介绍
- SThtmlDialog例子,MFC嵌入HTML控件的方法
- Struts2下进行html转义的方法(解决页面输出html标签问题)
- (html转换)StringEscapeUtils类的转义与反转义方法