首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >指令不接收对象为param

指令不接收对象为param
EN

Stack Overflow用户
提问于 2016-06-28 14:01:30
回答 1查看 123关注 0票数 0

我正在用AngularJS版本1.5.7编写代码。

由于某种原因,指令没有接收变量cdata,它是一个object

为什么指令不接收变量?

下面我粘贴了我所有的代码:

home.js

代码语言:javascript
复制
'use strict';

var home = angular.module('app.home', [
  'global.factory',
  'home.factory',
  'ui.scroll',
  'ui.scroll.jqlite',
  'd.card'
]);

home.controller('HomeController', [
  'homeFactory',
  '$timeout',
  function (homeFactory, $timeout) {

    var data = this;

    data.posterSize = (screen.width - 42) / 3;

    homeFactory.getJSON().then(function (response) {
      data.feed = response.home;
    });

    data.datasource = {
      get: function(index, count, success) {
        $timeout(function() {
          var start = Math.max(0, index);
          var end = Math.min(index + count, data.feed.length);

          var results = [];
          for (var i = start; i < end; i++) {
            results.push(data.feed[i]);
          }

          success(results);
        }, 100);
      }
    };
  }
]);

_home.html

代码语言:javascript
复制
<article ng-controller="HomeController as myHome" class="base-gen" ui-scroll-viewport style="height:100%">
  <card class="card" ui-scroll="element in myHome.datasource" cdata="{{element}}" psize="{{myHome.posterSize}}"></card>
</article>

card.js

代码语言:javascript
复制
'use strict';

var dCard = angular.module('d.card', ['global.factory']);

dCard.directive('card', [ 'globalImages', function (globalImages) {
  return {
    restrict: 'E',
    scope: {
      cdata: '@',
      psize: '@'
    },
    controller: function() {
      console.log(this.cdata);
    },
    controllerAs: 'myCard',
    bindToController: true,
    templateUrl: 'app/Modules/card.html'
  };
}]);

我还想指出,我已经从angular 1.4.8迁移到1.5.7,从ui-router 0.2.15迁移到0.3.1

EN

回答 1

Stack Overflow用户

发布于 2016-06-28 14:05:58

指令中的绑定是"=",这意味着角将为您完成绑定。不需要{{ }}

代码语言:javascript
复制
 <article ng-controller="HomeController as myHome" class="base-gen" ui-scroll-  viewport style="height:100%">
   <card class="card" ui-scroll="element in myHome.datasource" cdata="element" psize="{{myHome.posterSize}}"></card>
 </article>

对于psize,我不确定您是否需要{{ }},但是对于cdata,不需要括号

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

https://stackoverflow.com/questions/38078349

复制
相关文章

相似问题

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