繁体   English   中英

Angular在指令中的元素外部单击

[英]Angular Click outside of an element in directive

CSS

ul {
   display: none
}
span.active+ul {
   display:block
}

HTML

<div ng-controller='exchangeFormCtr'>
    <div toggle-class="active">
       <ul>
           <li ng-repeat='carrency in carrencies'>
       </ul>
    </div>
    <div toggle-class="active">
       <ul>
           <li ng-repeat='carrency in carrencies'>
       </ul>
    </div>   
</div>

调节器

exchange.controller('exchangeFormCtr',['$scope', function($scope) {
    $scope.carrencies = [
        {name:'mastercard'},
        {name:'visa'},
        {name:'paypal'}
    ];
}]);

指示

app.directive('toggleClass', function() {
    return {
        restrict: 'A',
        link: function(scope, element, attrs) {
            element.bind('click', function() {
                console.log(element);
                element.toggleClass(attrs.toggleClass);
            });
    }
};

当我单击span指令将类更改为活动或删除它时。

如何捕获外部点击事件并通过角度方式删除活动类?

您可以沿元素单击的stopPropagation()向文档对象添加一个单击处理程序。

 var app = angular.module('my-app', [], function () {}) app.controller('AppController', function ($scope) { $scope.message = "Welcome"; }); app.directive('toggleClass', function ($document) { return { restrict: 'A', link: function (scope, element, attrs) { console.log(element) function elementClick(e) { e.stopPropagation(); element.toggleClass(attrs.toggleClass); } function documentClick(e) { element.removeClass(attrs.toggleClass); } element.on('click', elementClick); $document.on('click', documentClick); // remove event handlers when directive is destroyed scope.$on('$destroy', function () { element.off('click', elementClick); $document.off('click', documentClick); }); } }; }); 
 .active { color: red } 
 <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script> <div ng-app="my-app" ng-controller="AppController"> <span toggle-class="active">ff</span> </div> asdf 

您的指令中有一些缺少的结尾字符。 看到这个工作小提琴

myApp.controller('exchangeFormCtr',['$scope', function($scope) {
    $scope.carrencies = [
        {name:'mastercard'},
        {name:'visa'},
        {name:'paypal'}
    ];
}

myApp.directive('toggleClass', function() {
    return {
        restrict: 'A',
        link: function(scope, element, attrs) {
            element.bind('click', function() {
                console.log(element);
                element.toggleClass(attrs.toggleClass);
            });
        }
    }
});

使用ng-class和一些filters来提取选定的值

 var exchange = angular.module('App', []); exchange.controller('exchangeFormCtr', ['$scope', function($scope) { $scope.carrencies = [{ name: 'mastercard' }, { name: 'visa' }, { name: 'paypal' }]; $scope.selectAll = function() { angular.forEach( $scope.carrencies, function(carrency) { console.log('ici') carrency.active = true; }); } } ]); 
 .active { background-color: green; color: orange; } 
 <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script> <div ng-app="App" ng-controller="exchangeFormCtr"> <span ng-click="selectAll()">select all!</span> <p ng-repeat="selected in carrencies"> <span ng-class="{active: selected.active}" ng-click="selected.active = !selected.active"> {{selected.name}} {{selected.active}} </span> </p> <p>actives are : <span>{{ carrencies | filter: {active:true} }}</span></p> </div> 

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM