在這一步,你會(huì)在手機(jī)詳細(xì)信息頁(yè)面讓手機(jī)圖片可以點(diǎn)擊。
請(qǐng)重置工作目錄:
git checkout -f step-10
手機(jī)詳細(xì)信息視圖展示了一幅當(dāng)前手機(jī)的大號(hào)圖片,以及幾個(gè)小一點(diǎn)的縮略圖。如果用戶點(diǎn)擊縮略圖就能把那張大的替換成自己那就更好了?,F(xiàn)在我們來看看如何用AngularJS來實(shí)現(xiàn)它。
步驟9和步驟10之間最重要的不同在下面列出。你可以在GitHub里看到完整的差別。
app/js/controllers.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
控制器中,我們創(chuàng)建了mainImageUrl
模型屬性,并且把它的默認(rèn)值設(shè)為第一個(gè)手機(jī)圖片的URL。
app/partials/phone-detail.html
<img ng-src="{{mainImageUrl}}" class="phone">
...
<ul class="phone-thumbs">
<li ng-repeat="img in phone.images">
<img ng-src="{{img}}" ng-click="setImage(img)">
</li>
</ul>
...
我們把大圖片的ngSrc
指令綁定到mainImageUrl
屬性上。
同時(shí)我們注冊(cè)一個(gè)ngClick處理器到縮略圖上。當(dāng)一個(gè)用戶點(diǎn)擊縮略圖的任意一個(gè)時(shí),這個(gè)處理器會(huì)使用setImage
事件處理函數(shù)來把mainImageUrl
屬性設(shè)置成選定縮略圖的URL。
為了驗(yàn)證這個(gè)新特性,我們添加了兩個(gè)端到端測(cè)試。一個(gè)驗(yàn)證主圖片被默認(rèn)設(shè)置成第一個(gè)手機(jī)圖片。第二個(gè)測(cè)試點(diǎn)擊幾個(gè)縮略圖并且驗(yàn)證主圖片隨之合理的變化。
test/e2e/scenarios.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');
});
});
});
你現(xiàn)在可以刷新你的瀏覽器,然后重新跑一遍端到端測(cè)試,或者你可以在AngularJS的服務(wù)器上運(yùn)行一下。
為PhoneDetailCtrl
添加一個(gè)新的控制器方法:
$scope.hello = function(name) {
alert('Hello ' + (name || 'world') + '!');
}
并且添加:
<button ng-click="hello('Elmo')">Hello</button>
到phone-details.html模板。
現(xiàn)在圖片瀏覽器已經(jīng)做好了,我們已經(jīng)為步驟11(最后一步啦?。┳龊昧藴?zhǔn)備,我們會(huì)學(xué)習(xí)用一種更加優(yōu)雅的方式來獲取數(shù)據(jù)。
更多建議: