【问题标题】:Difference between ng-bind, ng-bind-html, ng-bind-html-unsafe in AngularJS?AngularJS 中 ng-bind、ng-bind-html、ng-bind-html-unsafe 之间的区别?
【发布时间】:2015-02-19 05:28:45
【问题描述】:

我想知道ng-bindng-bind-htmlng-bind-html-unsafe 之间的区别。

另外,当我运行以下代码时,我收到如下所述的错误:

代码:

 <%@ page language="java" contentType="text/html; charset=ISO-8859-1"
        pageEncoding="ISO-8859-1"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>HTML Injection Security in AngularJS</title>

<script type="text/javascript" src="/js/angular.js"></script>

<script type="text/javascript">

angular.module("myApp", []).controller("myController",function($scope)
{
    $scope.getValue = function()
    {
        return "<b>Hello World</b>";
    };
});

</script>

</head>
<body>

<div ng-app="myApp" ng-controller="myController">
    <span ng-bind-html="getValue();"></span>
    <span>Normal Text</span>
</div>

</body>
</html>

错误:

错误:[$sce:unsafe] 试图在安全上下文中使用不安全的值。 http://errors.angularjs.org/1.3.11/$sce/不安全 在 REGEX_STRING_REGEXP (https://www.angularapprj.com:4443/js/angular.js:63:12) 在 htmlSanitizer (https://www.angularapprj.com:4443/js/angular.js:15053:13) 在 getTrusted (https://www.angularapprj.com:4443/js/angular.js:15217:16) 在 Object.$get.sce.(匿名函数) [as getTrustedHtml] (https://www.angularapprj.com:4443/js/angular.js:15897:16) 在 Object.ngBindHtmlWatchAction [as fn] (https://www.angularapprj.com:4443/js/angular.js:20449:29) 在 Scope.$get.Scope.$digest (https://www.angularapprj.com:4443/js/angular.js:14230:29) 在 Scope.$get.Scope.$apply (https://www.angularapprj.com:4443/js/angular.js:14493:24) 在 bootstrapApply (https://www.angularapprj.com:4443/js/angular.js:1449:15) 在 Object.invoke (https://www.angularapprj.com:4443/js/angular.js:4182:17) 在 doBootstrap (https://www.angularapprj.com:4443/js/angular.js:1447:14)

这是什么意思?我知道在命令式代码中使用声明性代码不是一个好习惯,尽管我只是在 ng-bind-html 指令中尝试使用 &lt;b&gt;Hello World&lt;/b&gt;

【问题讨论】:

    标签: javascript angularjs ng-bind-html ng-bind


    【解决方案1】:

    在搜索后,我从https://docs.angularjs.org/guide/migration#ngbindhtmlunsafe-has-been-removed-and-replaced-by-ngbindhtml 获得了以下信息:在 Angular 1.3 版中,他们已经从 ng-bind-html-unsafe 迁移到 ng-bind-html,尽管还有一点问题,为什么我会收到错误帖子里有提到吗?

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2013-09-26
      • 1970-01-01
      • 2013-06-18
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2016-05-29
      相关资源
      最近更新 更多