0

我正在发现 AngularJS 指令,并且在将对象的属性绑定到模板时遇到了问题。

我有一个不同内容类型(jpg、mp4)的项目列表,我试图通过在关于内容类型的 img 标签和 video 标签之间切换来自定义 DOM。

我有一个控制器,它使用工厂作为从上一个视图中获取选定对象的依赖项:

app.controller('EventDetailCtrl', function($scope, Events) {
   $scope.event = Events.getCurrentEvent();
}

然后,我有我的指令:

angular.module('starter.directives', [])
.directive('myEventDirective', ['$compile', 'API_ENDPOINT', function($compile, API_ENDPOINT){
  var imgTemplate = '<img ng-src="' + API_ENDPOINT.url + '/events/image/{{event._id}}" />';

  var videoTemplate = '<video controls="controls" preload="metadata" webkit-playsinline="webkit-playsinline" class="videoPlayer">' + 
    '<source src="' + API_ENDPOINT.url + '/events/video/{{event._id}}" type="video/mp4"/> </video>';

  var getTemplate = function(contentType){
    var template = '';
    if(contentType == 'mp4'){
       template = videoTemplate;
    } else { 
     template = imgTemplate; 
    }
    return template;
  };

  return {
    restrict: 'E',
    replace: true,
    link: function(scope, element, attrs){
      console.log(scope.event);
      element.html(getTemplate(scope.event.contentType));
      compile(element.contents())(scope);
    }
  }
}]);

在我的 console.log(scope.event) 上,浏览器正在打印具有所有属性(_id、contentType、文件名等)的对象。

还有我的 HTML 视图,我想在其中更新关于内容类型的标签:

<ion-view view-title="{{event.name}}">
  <ion-content class="padding">
   <my-event-directive data-source="event"></my-event-directive>
   <ion-item>
     Information about event do write
   </ion-item>
<ion-view />

但我有错误消息:

错误:[$interpolate:noconcat] 插值时出错:http: //192.168.1.11 :8100/api/events/video/ {{event._id}} 严格上下文转义不允许在需要可信值时连接多个表达式的插值.

我已经尝试将属性范围添加到指令的返回对象,但是我有一个未定义的对象......

感谢您的帮助!

编辑:

我在互联网上发现问题出在视频 url 上(它是针对 XSS 攻击的保护),但我不知道如何自定义我的 DOM 的这一部分并避免任何安全缺失..

4

1 回答 1

1

您可以使用 $sce 服务返回受信任的资源。

在 src 中提供一个来自您的范围的函数,该函数将返回一个受信任的资源 URL。

$scope.getResourceURL() {
    return $sce.trustAs($sce.RESOURCE_URL, yourURLhere);
}

文档:https : //docs.angularjs.org/api/ng/service/ $sce

于 2017-03-24T16:34:59.667 回答