Backbone.Model
Google Books API ボリュームを表すこれを取得しました。
var Book = Backbone.Model.extend({
defaults: {
volumeInfo : {
title: 'n.a.',
authors: 'n.a.',
publisher: 'n.a.',
publishedDate: 'n.a.',
imageLinks : {
smallThumbnail: '/unavailable.jpg'
}
}
},
parse: function(resp) {
if (resp.volumeInfo.authors) {
resp.volumeInfo.authors = resp.volumeInfo.authors.join(',');
}
return resp;
}
});
このテンプレートに供給されるもの:
<script type="text/template" id="bookCollectionRow">
<tr>
<td><img class="thumbnail" src="<%= volumeInfo.imageLinks.smallThumbnail %>" /></td>
<td><a target="_blank" href="<%= volumeInfo.canonicalVolumeLink %>"><%= volumeInfo.title %></a></td>
<td><%= volumeInfo.authors %></td>
<td><%= volumeInfo.publisher %></td>
<td><%= volumeInfo.publishedDate %></td>
</tr>
</script>
テンプレートの解析時に、ボリューム JSON に含まれていない場合、imageLinks
次のエラーが表示されます。
Uncaught TypeError: Cannot read property 'smallThumbnail' of undefined.
または でif
チェックすることで修正できることはわかっていますが、モデルプロパティの目的は何ですか? オーバーライドしない場合にのみ機能しますか?Model
template
defaults
parse