【发布时间】:2015-09-19 16:22:21
【问题描述】:
任何想法为什么在使用 jquery 超时功能添加类时角度手表不起作用。这个想法是,当 jquery 被用来改变 class: angular 来捕捉那个新类。小提琴中的工作示例。当您向下滚动时,您将看到捕获的班级变化 已解决:Fiddle
<div ng-app='myApp'>
<div ng-controller="Ctrl" class="holder">
<div class="pusher"></div>
<table id="table">
<thead>
<tr>
<th class="ui sticky gar" ng-repeat="friend in friends" add-remove-class>{{friend.name}}</th>
</tr>
</thead>
<tbody></tbody>
</table>
<div class="pusher"></div>
<div class="pusher"></div>
<div class="ui sticky" id="gar" add-remove-class>Garrrrr</div>
</div>
<p class="footer" ng-class="wohooOrNoo">footer</p>
</div>
var myApp = angular.module('myApp', []);
myApp.controller("Ctrl", function ($scope, $timeout) {
$('#gar').sticky();
$('gar').sticky();
$scope.friends = [
{name:'John', age:25, gender:'boy'},
{name:'Jessie', age:30, gender:'girl'},
{name:'Johanna', age:28, gender:'girl'},
{name:'Joy', age:15, gender:'girl'},
{name:'Mary', age:28, gender:'girl'},
{name:'Peter', age:95, gender:'boy'},
{name:'Sebastian', age:50, gender:'boy'},
{name:'Erika', age:27, gender:'girl'},
{name:'Patrick', age:40, gender:'boy'},
{name:'Samantha', age:60, gender:'girl'}
]
});
myApp.directive('addRemoveClass', function () {
return {
link: function link(scope, element, attrs) {
// create an observer instance
var observer = new MutationObserver(function (mutations) {
scope.$apply(function () {
if (element.hasClass('fixed')) {
alert("wee");
}
});
});
// configuration of the observer:
var config = {
attributes: true
};
// pass in the target node, as well as the observer options
var node = element.get(0);
observer.observe(node, config);
}
};
});
【问题讨论】:
-
你想达到什么目的?
-
元素不能这样看。
-
我的目的是:如果元素有类来触发函数
-
@ngLover 非常感谢。你能投票赞成我的问题吗
标签: javascript jquery angularjs angularjs-directive watch