我有一个关于使用纯JavaScript和使用jQuery与AngularJS一起使用时的性能问题。
例如:
app.directive('fitHeight', function($window) {
return {
restrict: 'A',
link: function(s){
s.contentminHeight = $window.innerHeight - 40 + 'px';
var h = $window.innerHeight;
$(window).resize(function() {
if ( h !== $window.innerHeight ) {
h = $window.innerHeight;
s.contentminHeight = ( h - 40 ) + 'px';
s.$apply();
}
});
}
};
});
我看到使用AngularJS对$window的大小进行验证已被弃用,其他选项是创建一个Interval来检查,我发现jquery.resize更可接受。
或者
app.directive('leftmenuDropdown', function() {
return {
restrict: 'C',
link: function(s, e){
e.click(function(){
var m = $(e.parent().find("ul")[0]);
if ( m.hasClass('dd-open') ) { m.removeClass('dd-open') } else { m.addClass('dd-open') }
});
}
};
});
我在Google上搜索了一下,理解为.hasClass比纯JavaScript更快。
关于性能问题,应该怎么做?是保留jQuery和AngularJS还是只使用纯JS的AngularJS?