AngularJS错误:$ interpolate:使用$ routeParams的interr插值错误

时间:2016-05-05 06:52:51

标签: javascript angularjs iframe angular-routing

我正在尝试将动态链接从json加载到我的iframe模板中。当我加载iframe页面时,会弹出此错误。我真的不知道为什么。这是我第一次看到这个错误。这是下面的代码。

控制器

app.controller('apps', [
'$scope', 
'$http', 
'contentService',
'gotoService',
'getIndex', 
'$routeParams', function($scope, $http, contentService, gotoService,  getIndex, $routeParams){
 contentService.then(function(data){
    $scope.data = data;   // access all data
    $scope.appsList = $scope.data.appsList;  // list of shortcuts

    // change url to links
    $scope.goTo= function(url){
        gotoService.getLink(url);
    }

    // get index
    $scope.getIndex = function(index){
        getIndex.current(index);
    }

    // embed in iframe
    $scope.link = function(){
        $scope.indexRoute = $routeParams.index;
       return $scope.appsList[$scope.indexRoute].url;
    }
});

}]);

iframe模板

<iframe ng-controller="apps" ng-src="{{link()}}" width="800"   height="600">
</iframe>

apps图标模板

<div class="apps-background" ng-click="goTo(a.link+'/'+$index); getIndex($index);" ng-style="{'background-image':'url({{a.image}})', 'background-repeat': 'no-repeat', 'background-size': 'cover'}">

2 个答案:

答案 0 :(得分:1)

你不能在ng-style指令表达式中使用插值指令,你需要像下面那样纠正它。

<div class="apps-background" 
  ng-click="goTo(a.link+'/'+$index); getIndex($index);" 
  ng-style="{'background-image': 'url('+ a.image + ')', 'background-repeat': 'no-repeat', 'background-size': 'cover'}">

Similar answer

答案 1 :(得分:0)

我解决了这个问题。我将控制器中的代码更改为此,它完美无缺。

app.controller('apps', [
'$scope', 
'$http', 
'contentService',
'gotoService',
'getIndex', 
'$routeParams', 
'$sce', function($scope, $http, contentService, gotoService, getIndex,  $routeParams, $sce){
   contentService.then(function(data){
    $scope.data = data;   // access all data
    $scope.data = data;   // access all data
    $scope.appsList = $scope.data.appsList;  // list of shortcuts

    // change url to links
    $scope.goTo= function(url){
        gotoService.getLink(url);
    }

    // get index
    $scope.getIndex = function(index){
        getIndex.current(index);
    }

    // embed in iframe
    $scope.link = function(){
        $scope.indexRoute = $routeParams.index;
       return $sce.trustAsResourceUrl($scope.appsList[$scope.indexRoute].url);
    }
});

}]);