我一直在做一個側面項目,並遇到了障礙。我可以搜索標籤並顯示他們的圖片結果,但我還想在每張圖片下面詳細說明位置信息。我在Javascript中這樣做,並且將我認爲需要調整的行註釋掉了,但註釋標記被刪除,甚至沒有顯示圖片。有小費嗎?通過對Instagram的通話印刷的JSON對象返回此數據:從圖像獲取位置數據(Instagram/JS)
Object
- data: Array[20]
- 0: Object
+ caption: Object
+ comments: Object
created_time: "1334402906"
filter: "Nashville"
id: "169306311223447303_5913362"
- images: Object
+ low_resolution: Object
- standard_resolution: Object
height: 612
url: "http://distilleryimage7.instagram.com/f3f8d7b2862411e19dc71231380fe523_7.jpg"
width: 612
+ thumbnail: Object
+ likes: Object
link: "http://instagr.am/p/JZfzFqtI8H/"
location: Object
tags: Array[1]
type: "image"
user: Object
我的代碼如下所示:
// Instantiate an empty object.
var Instagram = {};
// Small object for holding important configuration data.
Instagram.Config = {
clientID: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
apiHost: 'https://api.instagram.com'
};
// ************************
// ** Main Application Code
// ************************
(function(){
var photoTemplate, resource;
function init(){
bindEventHandlers();
photoTemplate = _.template($('#photo-template').html());
}
function toTemplate(photo){
photo = {
count: photo.likes.count,
avatar: photo.user.profile_picture,
photo: photo.images.low_resolution.url,
url: photo.link
//location: photo.location <--------------------------This line.
};
return photoTemplate(photo);
}
function toScreen(photos){
var photos_html = '';
//var photos_location = ''; <------------------------This line.
$('.paginate a').attr('data-max-tag-id', photos.pagination.next_max_id)
.fadeIn();
$.each(photos.data, function(index, photo){
photos_html += toTemplate(photo);
//photos_location += toTemplate(photo); <-----------------This line.
});
$('div#photos-wrap').append(photos_html);
//$('div#photos-wrap').append(photos_location) <------------------This line.
}
function generateResource(tag){
var config = Instagram.Config, url;
if(typeof tag === 'undefined'){
throw new Error("Resource requires a tag. Try searching for cherry blossoms.");
} else {
// Make sure tag is a string, trim any trailing/leading whitespace and take only the first
// word, if there are multiple.
tag = String(tag).trim().split(" ")[0];
}
// Configures the URL to search for pictures that fit the tag description.
url = config.apiHost + "/v1/tags/" + tag + "/media/recent?callback=?&client_id=" + config.clientID;
return function(max_id){
var next_page;
if(typeof max_id === 'string' && max_id.trim() !== '') {
next_page = url + "&max_id=" + max_id;
}
return next_page || url;
};
}
function paginate(max_id){
$.getJSON(generateUrl(tag), toScreen);
}
function search(tag){
resource = generateResource(tag);
$('.paginate a').hide();
$('#photos-wrap *').remove();
fetchPhotos();
}
function fetchPhotos(max_id){
$.getJSON(resource(max_id), toScreen);
}
function bindEventHandlers(){
$('body').on('click', '.paginate a.btn', function(){
var tagID = $(this).attr('data-max-tag-id');
fetchPhotos(tagID);
return false;
});
// Bind an event handler to the `submit` event on the form
$('form').on('submit', function(e){
// Stop the form from fulfilling its destinty.
e.preventDefault();
// Extract the value of the search input text field.
var tag = $('input.search-tag').val().trim();
// Invoke `search`, passing `tag` (unless tag is an empty string).
if(tag) {
search(tag);
};
});
}
function showPhoto(p){
$(p).fadeIn();
}
// Public API
Instagram.App = {
search: search,
showPhoto: showPhoto,
init: init
};
}());
$(function(){
Instagram.App.init();
Instagram.App.search('takoyaki');
});
你有你的代碼的的jsfiddle?你有沒有看過控制檯,看看你有什麼錯誤? – Xotic750 2013-05-12 23:19:07
http://jsfiddle.net/FNM7G/1/ - 雖然我搞砸了某個地方。我記不起該網站是爲了我的生活,很高興你提到它。謝謝!我不完全確定錯誤。 – user2371067 2013-05-12 23:30:26
我其實只是試圖擴大本網站:http://grammy.eduvoyage.com/ 功能是一樣的,但我想從每張圖片拉額外的信息。在某些情況下,我想獲取這些位置ID並將其顯示在圖像下方的Google地圖上。 – user2371067 2013-05-12 23:31:14