angularjs html反转义,AngularJS中取消对HTML片段转义的方法例子

这篇博客介绍了在AngularJS中如何处理并显示HTML片段。当从Rails后端获取JSON数据,AngularJS默认会转义HTML内容。通过使用 AngularJS 的 $sce 服务,可以将HTML片段标记为安全,从而在前端正确地显示。具体做法是使用 $sce.trustAsHtml() 方法将HTML片段标记为安全,再结合 data-ng-bind-html 指令,即可在页面上取消转义并显示HTML内容。文章提供了一个实例,展示如何遍历获取的posts,对每个post的html_body属性进行处理,将其转换为trustedBody,然后在视图中使用data-ng-bind-html来呈现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这篇文章主要介绍了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 部分

复制代码 代码如下:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值