AngularJS - 指令 + ng-repeat,5 个元素,循环 15 次
AngularJS - Directive + ng-repeat, 5 elements, loops 15 times
我尝试将动态图片添加到我的 div 中,这是我通过 url2img 插件实现的。效果很好。但是当我通过 ng-repeat 循环时,它会为我循环中的每个 div 加载最后一张图片。所以它循环了 15 次。我有 2 种方法现在不起作用。
1.) HTML + load-img-from-ext<-指令
<div ng-repeat="link in links">
<div class="jumbotron">
<div>
{{link.title}}
</div>
<div>
<img class="img-thumbnail img-thumb-ext" id="thumb-{{$index}}" src="%3D" load-img-from-ext="{{link.url}}"/>
</div>
</div>
</div>
1.) 指令
.directive("loadImgFromExt", ['$timeout', function (timer) {
return {
link: timer(function (scope, elem, attr) {
$(".img-thumb-ext").each(function () {
console.log(attr[loadImgFromExt]);
$.ajax({
url: 'https://www.googleapis.com/pagespeedonline/v1/runPagespeed?url=' + attr["loadImgFromExt"] + '&screenshot=true',
context: this,
type: 'GET',
dataType: 'json',
success: function (data) {
data = data.screenshot.data.replace(/_/g, '/').replace(/-/g, '+');
$(this).attr('src', 'data:image/jpeg;base64,' + data);
}
});
})
}
}
}
}])
在屏幕上呈现的 5 个元素循环 15 次。
所以控制台日志的输出是
0
0 1
0 1 2
0 1 2 3
0 1 2 3 4
我的图片 src 被最后一张图片覆盖了。
2.) 第二种方法
HTML + emit-last-repeater-element<-指令
+data-url in img
<div ng-repeat="link in links" emit-last-repeater-element>
<div class="jumbotron">
<div>
{{link.title}}
</div>
<div>
<img class="img-thumbnail img-thumb-ext" id="thumb-{{$index}}" src="%3D" alt="{{link.url}}" data-url="{{link.url}}"/>
</div>
</div>
</div>
</div>
2.) 指令
.directive('emitLastRepeaterElement', function() {
return function(scope) {
if (scope.$last){
scope.$emit('LastRepeaterElement');
}
};
});
2.) 调用
的控制器
$scope.$on('LastRepeaterElement', function(){
console.log('good to go');
$('img[data-url]').each(function() {
console.log($(this)[0].attributes[3])
console.log($(this)[0].attributes[3].nodeValue);
//var myUrl = $(this)[0].attributes[3];
console.log($(this).data('url'));
$.ajax({
url: 'https://www.googleapis.com/pagespeedonline/v1/runPagespeed?url=' + $(this).data('url') + '&screenshot=true',
context: this,
type: 'GET',
dataType: 'json',
success: function(data) {
data = data.screenshot.data.replace(/_/g, '/').replace(/-/g, '+');
$(this).attr('src', 'data:image/jpeg;base64,' + data);
}
});
});
});
这行得通,所以它只循环了 5 次。但是 $(this).data('url');
输出 {{link.url}}
,而不是像 http://www.google.com
.
这样的 url
$(this)[0].attributes[3]
输出 data-url="http://www.google.com"
并且是 object
的一种
$(this)[0].attributes[3].nodeValue ouputs {{link.url}}
是 string
的一种
谁能告诉我如何只循环 5 次并获得正确格式的 url?
所以 {{link.url}}
应该是http://www.google.com or http://www.yahoo.com 这样我就可以在我的 ajax 请求中的 url
属性 中使用它。
我开始相信 jQuery 专业知识是学习的积极障碍 Angular:您习惯的许多技术与您在 Angular。您显然习惯于将 DOM 用作数据存储——在 Angular 中,您需要将其更多地视为数据模型的副作用表示。
每个指令都有自己的 link.url
作用域,因此无需遍历 jQuery 中的 DOM 并收集每个 link.url
指示。同样,没有理由继续读取和设置 DOM 属性的数据——使用指令范围;您需要的所有数据都已经存在。
<div ng-repeat="link in links">
<div class="jumbotron">
<div>{{link.title}}</div>
<div>
<img ng-src="{{link.parsedUrl}}">
</div>
</div>
</div>
...并在指令 link 函数中,直接从 link.url
:
构造 link.parsedUrl
$.ajax({ // or, better, use $http
url: 'https://www.googleapis.com/pagespeedonline/v1/runPagespeed?url=' + scope.link.url + '&screenshot=true',
context: this,
type: 'GET',
dataType: 'json',
success: function(data) {
data = data.screenshot.data.replace(/_/g, '/').replace(/-/g, '+');
scope.link.parsedUrl = 'data:image/jpeg;base64,' + data;
}
});
我尝试将动态图片添加到我的 div 中,这是我通过 url2img 插件实现的。效果很好。但是当我通过 ng-repeat 循环时,它会为我循环中的每个 div 加载最后一张图片。所以它循环了 15 次。我有 2 种方法现在不起作用。
1.) HTML + load-img-from-ext<-指令
<div ng-repeat="link in links">
<div class="jumbotron">
<div>
{{link.title}}
</div>
<div>
<img class="img-thumbnail img-thumb-ext" id="thumb-{{$index}}" src="%3D" load-img-from-ext="{{link.url}}"/>
</div>
</div>
</div>
1.) 指令
.directive("loadImgFromExt", ['$timeout', function (timer) {
return {
link: timer(function (scope, elem, attr) {
$(".img-thumb-ext").each(function () {
console.log(attr[loadImgFromExt]);
$.ajax({
url: 'https://www.googleapis.com/pagespeedonline/v1/runPagespeed?url=' + attr["loadImgFromExt"] + '&screenshot=true',
context: this,
type: 'GET',
dataType: 'json',
success: function (data) {
data = data.screenshot.data.replace(/_/g, '/').replace(/-/g, '+');
$(this).attr('src', 'data:image/jpeg;base64,' + data);
}
});
})
}
}
}
}])
在屏幕上呈现的 5 个元素循环 15 次。 所以控制台日志的输出是
0
0 1
0 1 2
0 1 2 3
0 1 2 3 4
我的图片 src 被最后一张图片覆盖了。
2.) 第二种方法 HTML + emit-last-repeater-element<-指令 +data-url in img
<div ng-repeat="link in links" emit-last-repeater-element>
<div class="jumbotron">
<div>
{{link.title}}
</div>
<div>
<img class="img-thumbnail img-thumb-ext" id="thumb-{{$index}}" src="%3D" alt="{{link.url}}" data-url="{{link.url}}"/>
</div>
</div>
</div>
</div>
2.) 指令
.directive('emitLastRepeaterElement', function() {
return function(scope) {
if (scope.$last){
scope.$emit('LastRepeaterElement');
}
};
});
2.) 调用
的控制器$scope.$on('LastRepeaterElement', function(){
console.log('good to go');
$('img[data-url]').each(function() {
console.log($(this)[0].attributes[3])
console.log($(this)[0].attributes[3].nodeValue);
//var myUrl = $(this)[0].attributes[3];
console.log($(this).data('url'));
$.ajax({
url: 'https://www.googleapis.com/pagespeedonline/v1/runPagespeed?url=' + $(this).data('url') + '&screenshot=true',
context: this,
type: 'GET',
dataType: 'json',
success: function(data) {
data = data.screenshot.data.replace(/_/g, '/').replace(/-/g, '+');
$(this).attr('src', 'data:image/jpeg;base64,' + data);
}
});
});
});
这行得通,所以它只循环了 5 次。但是 $(this).data('url');
输出 {{link.url}}
,而不是像 http://www.google.com
.
$(this)[0].attributes[3]
输出 data-url="http://www.google.com"
并且是 object
$(this)[0].attributes[3].nodeValue ouputs {{link.url}}
是 string
谁能告诉我如何只循环 5 次并获得正确格式的 url?
所以 {{link.url}}
应该是http://www.google.com or http://www.yahoo.com 这样我就可以在我的 ajax 请求中的 url
属性 中使用它。
我开始相信 jQuery 专业知识是学习的积极障碍 Angular:您习惯的许多技术与您在 Angular。您显然习惯于将 DOM 用作数据存储——在 Angular 中,您需要将其更多地视为数据模型的副作用表示。
每个指令都有自己的 link.url
作用域,因此无需遍历 jQuery 中的 DOM 并收集每个 link.url
指示。同样,没有理由继续读取和设置 DOM 属性的数据——使用指令范围;您需要的所有数据都已经存在。
<div ng-repeat="link in links">
<div class="jumbotron">
<div>{{link.title}}</div>
<div>
<img ng-src="{{link.parsedUrl}}">
</div>
</div>
</div>
...并在指令 link 函数中,直接从 link.url
:
link.parsedUrl
$.ajax({ // or, better, use $http
url: 'https://www.googleapis.com/pagespeedonline/v1/runPagespeed?url=' + scope.link.url + '&screenshot=true',
context: this,
type: 'GET',
dataType: 'json',
success: function(data) {
data = data.screenshot.data.replace(/_/g, '/').replace(/-/g, '+');
scope.link.parsedUrl = 'data:image/jpeg;base64,' + data;
}
});