• 控制器
  • 模板
  • 测试
  • 练习
  • 总结

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

    请重置工作目录:

    1. git checkout -f step-10

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

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

    控制器

    app/js/controllers.js

    1. ...
    2. function PhoneDetailCtrl($scope, $routeParams, $http) {
    3. $http.get('phones/' + $routeParams.phoneId + '.json').success(function(data) {
    4. $scope.phone = data;
    5. $scope.mainImageUrl = data.images[0];
    6. });
    7. $scope.setImage = function(imageUrl) {
    8. $scope.mainImageUrl = imageUrl;
    9. }
    10. }
    11. //PhoneDetailCtrl.$inject = ['$scope', '$routeParams', '$http'];

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

    模板

    app/partials/phone-detail.html

    1. <img ng-src="{{mainImageUrl}}" class="phone">
    2. ...
    3. <ul class="phone-thumbs">
    4. <li ng-repeat="img in phone.images">
    5. <img ng-src="{{img}}" ng-click="setImage(img)">
    6. </li>
    7. </ul>
    8. ...

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

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

    测试

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

    test/e2e/scenarios.js

    1. ...
    2. describe('Phone detail view', function() {
    3. ...
    4. it('should display the first phone image as the main phone image', function() {
    5. expect(element('img.phone').attr('src')).toBe('img/phones/nexus-s.0.jpg');
    6. });
    7. it('should swap main image if a thumbnail image is clicked on', function() {
    8. element('.phone-thumbs li:nth-child(3) img').click();
    9. expect(element('img.phone').attr('src')).toBe('img/phones/nexus-s.2.jpg');
    10. element('.phone-thumbs li:nth-child(1) img').click();
    11. expect(element('img.phone').attr('src')).toBe('img/phones/nexus-s.0.jpg');
    12. });
    13. });
    14. });

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

    练习

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

    1. $scope.hello = function(name) {
    2. alert('Hello ' + (name || 'world') + '!');
    3. }

    并且添加:

    1. <button ng-click="hello('Elmo')">Hello</button>

    phone-details.html模板。

    总结

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