AngularJS中取消对HTML片段转义的方法例子  更新时间:2015年01月04日 11:58:57   投稿:junjie   这篇文章主要介绍了AngularJS中取消对HTML片段转义的方法例子,在一些需要显示HTML的地方,就要取消AngularJS的转义,本文就介绍了这种方法,需要的朋友可以参考下 今天尝试用 Rails 做后端提供 JSON 格式的数据, AngularJS 做前端处理 JSON 数据,其中碰到 AngularJS 获取的是一段 HTML 文本,如果直接使用 data-ng-bind 的话是被转义过的,使用 data-ng-bind-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 部分 复制代码 代码如下: 您可能感兴趣的文章: 浅谈html转义及防止javascript注入攻击的方法 JS转换HTML转义符的方法 在JavaScript中对HTML进行反转义详解 使用php转义输出HTML到JavaScript 使用Js让Html中特殊字符不被转义 注释的艺术——JS里直接写HTML,无需转义 JS实现HTML标签转义及反转义 AngularJS 取消 HTML 转义 相关文章 详解Angular2学习笔记之Html属性绑定 本篇文章主要介绍了详解Angular2学习笔记之Html属性绑定,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 2018-01-01 Angular.js实现获取验证码倒计时60秒按钮的简单方法 最近做项目的时候又遇到了验证码倒计时的需求,发现这个功能还是挺实用的,所以就想着总结一下,下面这篇文章主要给大家介绍了关于利用Angular.js如何实现获取验证码倒计时按钮的简单方法,需要的朋友可以参考借鉴,下面来一起看看吧。 2017-10-10 AngularJS 中ui-view传参的实例详解 这篇文章主要介绍了AngularJS 中ui-view传参的实例详解的相关资料,这里提供实例帮助大家学习理解这部分内容,需要的朋友可以参考下 2017-08-08 详细AngularJs4的图片剪裁组件的实例 本篇文章主要介绍了详细AngularJs4的图片剪裁组件的实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 2017-07-07 详解angular element()方法使用 本篇文章主要介绍了详解angular element()方法使用,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 2017-04-04 老生常谈angularjs中的$state.go 下面小编就为大家带来一篇老生常谈angularjs中的$state.go。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧 2017-04-04 使用Angular CLI进行单元测试和E2E测试的方法 这篇文章主要介绍了使用Angular CLI进行单元测试和E2E测试的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 2018-03-03 angular ng-click防止重复提交实例 本篇文章主要介绍了angular ng-click防止重复提交实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 2017-06-06 Angularjs中使用指令绑定点击事件的方法 本篇文章主要介绍了Angularjs中使用指令绑定点击事件的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。 2017-03-03 AngularJS ng-repeat数组有重复值的解决方法 不知道大家是否遇到过这个问题,在当Angular.JS ng-repeat数组中有重复项时,系统就会抛出异常,这是该怎么做?本文通过示例代码介绍了详细的解决方法,有需要的朋友们可以参考借鉴,下面来一起看看吧。 2016-10-10 最新评论

今天尝试用 Rails 做后端提供 JSON 格式的数据, AngularJS 做前端处理 JSON 数据,其中碰到 AngularJS 获取的是一段 HTML 文本,如果直接使用 data-ng-bind 的话是被转义过的,使用 data-ng-bind-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>

您可能感兴趣的文章:

  • 浅谈html转义及防止javascript注入攻击的方法
  • JS转换HTML转义符的方法
  • 在JavaScript中对HTML进行反转义详解
  • 使用php转义输出HTML到JavaScript
  • 使用Js让Html中特殊字符不被转义
  • 注释的艺术——JS里直接写HTML,无需转义
  • JS实现HTML标签转义及反转义
张贴在3