Angularjs 如何自定义Img的ng-load 事件

    在使用AngularJs的过程中,我们常常会用到一些ng-事件,如ng-click、ng-change等,这些事件都是AngularJs事先为我们定义好的。也有的情况下,我们会用到一些使用频率不高的dom事件,如img的onload(图片加载完成后触发),但AngularJs中默认没有这个事件,那么我们该如何自定义添加ng-load这个事件呢?

    只需要给app对象添加如下指令即可:

myApp.directive('imageonload', function () {
    return {
        restrict: 'A', link: function (scope, element, attrs) {
            element.bind('load', function () { 
                //call the function that was passed 
                scope.$apply(attrs.imageonload);
            });
        }
    };
})

在Html中直接使用imageonload属性追加事件:

<img ng-src="{{src}}" imageonload="doThis()" />

最后,在controller中写对应的事件内容即可:

$scope.doThis=function(){
 //your own code
}

 

posted on 2016-06-12 16:15  巴拉森  阅读(7677)  评论(1编辑  收藏  举报

导航