首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >删除ng-bind-html-unsafe后,如何注入HTML?

删除ng-bind-html-unsafe后,如何注入HTML?
EN

Stack Overflow用户
提问于 2013-10-17 06:57:42
回答 6查看 254K关注 0票数 269

我正在尝试使用HTML和ng-bind-htm-unsafe指令来允许我的控制器将$sanitize注入到ng-bind-htm-unsafe中。

然而,我不能让它工作。

代码语言:javascript
复制
<div ng-bind-html-unsafe="{{preview_data.preview.embed.html}}"></div>

我发现这是因为它已经从AngularJS中删除了(谢谢)。

但是如果没有ng-bind-html-unsafe,我会得到这样的错误:

http://errors.angularjs.org/undefined/$sce/unsafe

EN

回答 6

Stack Overflow用户

发布于 2014-01-21 17:53:46

您可以将其转换为一个简单的过滤器,而不是像Alex建议的那样,在您的作用域中声明一个函数:

代码语言:javascript
复制
angular.module('myApp')
    .filter('to_trusted', ['$sce', function($sce){
        return function(text) {
            return $sce.trustAsHtml(text);
        };
    }]);

然后你可以像这样使用它:

代码语言:javascript
复制
<div ng-bind-html="preview_data.preview.embed.html | to_trusted"></div>

下面是一个有效的示例:http://jsfiddle.net/leeroy/6j4Lg/1/

票数 354
EN

Stack Overflow用户

发布于 2013-10-17 10:51:45

您表示您使用的是Angular 1.2.0...正如另一条评论指出的那样,ng-bind-html-unsafe已被弃用。

取而代之的是,你会想要这样做:

代码语言:javascript
复制
<div ng-bind-html="preview_data.preview.embed.htmlSafe"></div>

在您的控制器中,注入$sce服务,并将其标记为"trusted":

代码语言:javascript
复制
myApp.controller('myCtrl', ['$scope', '$sce', function($scope, $sce) {
  // ...
  $scope.preview_data.preview.embed.htmlSafe = 
     $sce.trustAsHtml(preview_data.preview.embed.html);
}

请注意,您需要使用1.2.0-rc3或更高版本。(他们修复了rc3中阻止“观察者”在受信任的超文本标记语言上正常工作的a bug。)

票数 275
EN

Stack Overflow用户

发布于 2013-12-21 03:19:57

对我来说,最简单和最灵活的解决方案是:

代码语言:javascript
复制
<div ng-bind-html="to_trusted(preview_data.preview.embed.html)"></div>

并为您的控制器添加功能:

代码语言:javascript
复制
$scope.to_trusted = function(html_code) {
    return $sce.trustAsHtml(html_code);
}

不要忘记将$sce添加到控制器的初始化中。

票数 112
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19415394

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档