angular.js - angularjs中directive的ng-click为什么不能传递参数
滿天的星座
滿天的星座 2017-05-15 17:11:35
0
3
611

首先定义一个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);
    }
滿天的星座
滿天的星座

Antworte allen(3)
世界只因有你
$scope.changeConversation = function (conversation);

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

给我你的怀抱

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

我想大声告诉你

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

Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage