suchen

Heim  >  Fragen und Antworten  >  Hauptteil

angular.js - angularjs中directive的ng-click为什么不能传递参数

首先定义一个directive:

app.directive('conversation', [function() {
    return {
        restrict: 'E',
        templateUrl: 'conversation.html?date' + new Date().getTime(),
        replace: true,
        scope:{
            conversations:"=",
            changeConversation: "&"
        },
        link:function(scope, element, attributes){

        }
    };
}]);

调用

<conversation conversations="conversations" change-conversation="changeConversation(conversation)"></conversation>

<ul class="mdui-list">
    <li class="mdui-list-item mdui-ripple" ng-repeat="conversation in conversations" ng-click="changeConversation(conversation)">
        <p class="mdui-list-item-avatar">
            <img ng-src="{{conversation.chatThumbLogo}}"/>
        </p>
        <p class="mdui-list-item-content">
            <p class="mdui-list-item-title">{{conversation.chatName}}</p>
            <!--<p class="mdui-list-item-text mdui-list-item-one-line">hello world</p>-->
            <span class="im_badge" ng-bind="conversation.unreadCount" ng-if="conversation.unreadCount > 0"></span>
        </p>
    </li>
    <li class="mdui-pider-inset mdui-m-y-0"></li>
</ul>

ng-click触发函数后不能打印conversation,undefined。

 $scope.changeConversation = function (conversation) {
        console.log(conversation);
    }
滿天的星座滿天的星座2744 Tage vor573

Antworte allen(3)Ich werde antworten

  • 世界只因有你

    世界只因有你2017-05-15 17:13:35

    $scope.changeConversation = function (conversation);

    这里是parent的scope,你parent的scope里并没有conversation这个变量。

    Antwort
    0
  • 给我你的怀抱

    给我你的怀抱2017-05-15 17:13:35

    我也觉着是@熊丸子说的那样,conversation这个变量不是父级的

    Antwort
    0
  • 我想大声告诉你

    我想大声告诉你2017-05-15 17:13:35

    conversation 这个directive restrict: 'E', 是element ,你没有在template中引用

    Antwort
    0
  • StornierenAntwort