我发布了我的代码,因为为了我,我无法弄清楚为什么ng-mouseenter和ng-mouseleave无法正常工作......只有当鼠标进入时它们才会正确启动并且从侧面(左/右)离开并且有时候鼠标仍然没有启动..我不能使用css来应用所需的类,因为我必须注意按下ctrl键事件,所以我必须坚持ng-mouseenter / leave。我也试过ng-mouseover / out - 他们几乎根本不工作。知道为什么会这样,以及如何解决它?我会非常感激。
view.html
<div ng-controller="ControlCenterViewController as controlCenter">
<div class="controlcenter" ng-repeat="cat in controlCenter.categories">
<div class="controlcenter-category">{{cat.title}}</div>
<div class="controlcenter-shortcut" ng-repeat="shortcut in cat.exts"
ng-click="controlCenter.onSelect(shortcut, $event)" ng-class="class"
ng-mouseenter="controlCenter.hoverIn($event, shortcut)" ng-mouseleave="controlCenter.hoverOut($event, shortcut)">
<span class="shortcut-remove hidden-shortcut">
<clr-icon shape="times-circle" class="is-error" size="12"></clr-icon>
</span>
<span class="{{shortcut.icon}} controlcenter-shortcut-icon-display" ng-if="controlCenter.hasClass(shortcut)"></span>
<img class="controlcenter-shortcut-icon" ng-src="{{shortcut.icon}}" ng-if="!controlCenter.hasClass(shortcut)"/>
<div data-test-id="{{shortcut.targetViewUid}}" class="controlcenter-shortcut-label">{{shortcut.name}}</div>
</div>
</div>
</div>
controller.js
function hoverIn(event, shortcut){
if(perspectivesService.isEditEnabled()){
console.log('hover in fired');
var target = angular.element(event.target).find('span.shortcut-remove');
if(event.ctrlKey){
target.removeClass('hidden-shortcut');
target.addClass('current-shortcut');
}
}
}
function hoverOut(event, shortcut){
if(perspectivesService.isEditEnabled()){
console.log('hover out fired');
var target = angular.element(event.target).find('span.shortcut-remove');
target.removeClass('current-shortcut');
target.addClass('hidden-shortcut');
}
}
CSS
.hidden-shortcut {
display: none;
}
.current-shortcut {
display: block !important;
}
答案 0 :(得分:2)
当我在Angularjs中使用JQuery时,有几个问题。
我见过很多老年人推荐Do not use JQuery with Angularjs
,
所以我建议一个。
我希望这可以帮到你。 :)
检查这个小提琴。
myApp.controller('MyController', function($scope){
$scope.colorClass = 'red-div';
$scope.changeClass = function (css) {
$scope.colorClass = css;
};
});
也许这与你的目的不一样。
但如果您想了解更多信息,请给我一些反馈。 :)
答案 1 :(得分:0)
您可以将JQuery与Angularjs一起使用,但您必须将jQuery&#39; s符号设置为jQuery。