• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >AngularJS > AngularJS中取消对HTML片段转义的方法例子

AngularJS中取消对HTML片段转义的方法例子

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-30

本文主要包含AngularJS中取消对HTML片段转义的方法例子等相关知识,希望在学习及工作中可以帮助到您

今天尝试用 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.
</div>
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();
});
</div>
HTML 部分
<div class="post-body markup-body" data-ng-bind-html="post.trustedBody"></div>
</div>

</div>

您可能想查找下面的文章:

相关文章

  • 2017-05-30详解为Angular.js内置$http服务添加拦截器的方法
  • 2017-05-30angular2倒计时组件使用详解
  • 2017-05-30div实现自适应高度的textarea实现angular双向绑定
  • 2017-05-30详解Angular.js数据绑定时自动转义html标签及内容
  • 2017-05-30AngularJS入门教程(零):引导程序
  • 2017-05-30angular基于路由控制ui-router实现系统权限控制
  • 2017-05-30AngularJS 入门教程之事件处理器详解
  • 2017-05-30AngularJS框架的ng-app指令与自动加载实现方法分析
  • 2017-05-30Angularjs 动态改变title标题(兼容ios)
  • 2017-05-30浅谈angular2的http请求返回结果的subcribe注意事项

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • AngularJS中update两次出现$promise属性无法识别的解决方法
    • ANGULARJS中使用JQUERY分页控件
    • Angularjs+bootstrap+table多选(全选)支持单击行选中实现编辑、删除功能
    • Angularjs自定义指令实现三级联动 选择地理位置
    • AngularJS表格样式简单设置方法示例
    • Angularjs根据json文件动态生成路由状态的实现方法
    • 详解angularjs结合pagination插件实现分页功能
    • AngularJS实践之使用NgModelController进行数据绑定
    • 学习Angular中作用域需要注意的坑
    • AngularJS constant和value区别详解

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有