Kua*_*uan 4 loading document-ready angularjs
我想用来ng-repeat在页面中显示超过100个图像.这些图像在加载时花费了大量时间,我不希望显示它们被加载到用户.所以,我只想在浏览器中加载它们之后显示它们.
如果加载了所有图像,有没有办法检测?
jad*_*nda 11
你可以使用这样的load事件.
image.addEventListener('load', function() {
/* do stuff */
});
Run Code Online (Sandbox Code Playgroud)
角度指令
单个图像的解决方案
HTML
<div ng-app="myapp">
<div ng-controller="MyCtrl1">
<loaded-img src="src"></loaded-img>
<img ng-src="{{src2}}" />'
</div>
</div>
Run Code Online (Sandbox Code Playgroud)
JS
var myApp = angular.module('myapp',[]);
myApp
.controller('MyCtrl1', function ($scope) {
$scope.src = "http://lorempixel.com/800/200/sports/1/";
$scope.src2 = "http://lorempixel.com/800/200/sports/2/";
})
.directive('loadedImg', function(){
return {
restrict: 'E',
scope: {
src: '='
},
replace: true,
template: '<img ng-src="{{src}}" class="none"/>',
link: function(scope, ele, attr){
ele.on('load', function(){
ele.removeClass('none');
});
}
};
});
Run Code Online (Sandbox Code Playgroud)
CSS
.none{
display: none;
}
Run Code Online (Sandbox Code Playgroud)
http://jsfiddle.net/jigardafda/rqkor67a/4/
如果您看到jsfiddle演示,您会注意到src图像仅在图像完全加载后显示,而在src2您可以看到图像加载的情况下.(禁用缓存以查看差异)
多个图像的解决方案
HTML
<div ng-app="myapp">
<div ng-controller="MyCtrl1">
<div ng-repeat="imgx in imgpaths" ng-hide="hideall">
<loaded-img isrc="imgx.path" onloadimg="imgx.callback(imgx)"></loaded-img>
</div>
</div>
</div>
Run Code Online (Sandbox Code Playgroud)
JS
var myApp = angular.module('myapp',[]);
myApp
.controller('MyCtrl1', function ($scope, $q) {
var imp = 'http://lorempixel.com/800/300/sports/';
var deferred;
var dArr = [];
var imgpaths = [];
for(var i = 0; i < 10; i++){
deferred = $q.defer();
imgpaths.push({
path: imp + i,
callback: deferred.resolve
});
dArr.push(deferred.promise);
}
$scope.imgpaths = imgpaths;
$scope.hideall = true;
$q.all(dArr).then(function(){
$scope.hideall = false;
console.log('all loaded')
});
})
.directive('loadedImg', function(){
return {
restrict: 'E',
scope: {
isrc: '=',
onloadimg: '&'
},
replace: true,
template: '<img ng-src="{{isrc}}" class="none"/>',
link: function(scope, ele, attr){
ele.on('load', function(){
console.log(scope.isrc, 'loaded');
ele.removeClass('none');
scope.onloadimg();
});
}
};
});
Run Code Online (Sandbox Code Playgroud)
要检测是否所有图像都已加载,
对于每个图像,我生成一个deferred对象并将其deferred.resolve作为图像的onload回调传递给该deferred对象promise,然后将该对象推送到数组中.之后我常常$q.all检测所有这些承诺是否已经解决.
http://jsfiddle.net/jigardafda/rqkor67a/5/
更新:添加角度方式.
更新:添加了加载多个图像的解决方案.