0

我是 AngularJS 的新手,非常感谢您的建议。我有带图像的滑块:

 <ul rn-carousel rn-carousel-index="carouselIndex"  rn-carousel-buffered>
            <li ng-repeat="slide in slides track by slide.id" ng-class="'id-' + slide.id">
                <div ng-style="{'background-image': 'url(' + slide.image + ')'}"  class="bgimage">
                </div>
            </li>
        </ul>

在我的控制器中,我分配了$scope.slides一些图像数组:

$scope.slides = [];
$.each(defaultImages,function(i, element)
       {
          var slide = {
            image://...
          };
          $scope.slides.push(slide);
       });

另外,我有一个更改幻灯片数组的函数:

$scope.colorClicked = function ($index, color_id) {
    //...
    $scope.slides = [];
    $.each(images,function(i, element)  
       {
          var slide = {
           image:/...
          };
          $scope.slides.push(slide);
       });
  }

我有两个问题:

colorClicked1)它工作正常,但有时当我的函数触发时,当前显示在滑块上的图像并没有改变。

我想知道我应该以某种方式更新滑块或范围吗?我尝试$scope.$apply()了我的功能,但没有帮助。

2)即使我将数组传递给幻灯片集合,我仍然在控制台中遇到错误:Error: the slides collection must be an Array尽管我的滑块工作正常。

4

1 回答 1

0

解决方案错误'错误:幻灯片集合必须是错误的数组(本机)angular-carousel.min.js:8'

//Controller
$scope.banners = [];

Banners.getListBanners().then(function (banners) {
    $scope.banners = banners;
});

//view

<ul rn-carousel rn-carousel-auto-slide rn-carousel-transition="slide" ng-show="banners.length > 0">
            <li ng-repeat="banner in banners">
                <p ng-bind-html="banner.title | to_trusted"></p>

                <img ng-if="isBlank(banner.link)" ng-src="{{banner.img}}" alt="{{banner.title | to_trusted}}">

                <a ng-if="!isBlank(banner.link)" ng-click="openInExternalBrowser(banner.link, banner.type)" href="#">
                    <img ng-src="{{banner.img}}" alt="{{banner.title | to_trusted}}">
                </a>

            </li>
        </ul>
于 2016-08-03T13:17:28.510 回答