微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

AngularJS 入门教程之事件处理器详解

在这一步,你会在手机详细信息页面让手机图片可以点击。

请重置工作目录:

手机详细信息视图展示了一幅当前手机的大号图片,以及几个小一点的缩略图。如果用户点击缩略图就能把那张大的替换成自己那就更好了。现在我们来看看如何用AngularJS来实现它。

步骤9和步骤10之间最重要的不同在下面列出。你可以在GitHub里看到完整的差别。

控制器

app/js/controllers.js

rush:js;"> ... function PhoneDetailCtrl($scope,$routeParams,$http) { $http.get('phones/' + $routeParams.phoneId + '.json').success(function(data) { $scope.phone = data; $scope.mainImageUrl = data.images[0]; });

$scope.setimage = function(imageUrl) {
$scope.mainImageUrl = imageUrl;
}
}

//PhoneDetailCtrl.$inject = ['$scope','$routeParams','$http'];

在PhoneDetailCtrl控制器中,我们创建了mainImageUrl模型属性,并且把它的认值设为第一个手机图片的URL。

模板

app/partials/phone-detail.html

rush:js;"> ...

<ul class="phone-thumbs">
<li ng-repeat="img in phone.images">
<img ng-src="{{img}}" ng-click="setimage(img)">

...

我们把大图片的ngSrc指令绑定到mainImageUrl属性上。

同时我们注册一个ngClick处理器到缩略图上。当一个用户点击缩略图的任意一个时,这个处理器会使用setimage事件处理函数来把mainImageUrl属性设置成选定缩略图的URL。

测试

为了验证这个新特性,我们添加了两个端到端测试。一个验证主图片认设置成第一个手机图片。第二个测试点击几个缩略图并且验证主图片随之合理的变化。

test/e2e/scenarios.js

rush:js;"> ... describe('Phone detail view',function() {

...

it('should display the first phone image as the main phone image',function() {
expect(element('img.phone').attr('src')).toBe('img/phones/nexus-s.0.jpg');
});

it('should swap main image if a thumbnail image is clicked on',function() {
element('.phone-thumbs li:nth-child(3) img').click();
expect(element('img.phone').attr('src')).toBe('img/phones/nexus-s.2.jpg');

element('.phone-thumbs li:nth-child(1) img').click();
expect(element('img.phone').attr('src')).toBe('img/phones/nexus-s.0.jpg');
});
});
});

你现在可以刷新你的浏览器,然后重新跑一遍端到端测试,或者你可以在AngularJS的服务器上运行一下。

练习

为PhoneDetailCtrl添加一个新的控制器方法

rush:js;"> $scope.hello = function(name) { alert('Hello ' + (name || 'world') + '!'); }

并且添加

总结

现在图片浏览器已经做好了,我们已经为步骤11(最后一步啦!)做好了准备,我们会学习用一种更加优雅的方式来获取数据。

以上就是AngularJS 事件处理器的资料整理,后续继续补充,谢谢大家对本站的支持

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐