Создание стены Facebook при помощи jQuery шаблонов
В этом уроке мы хотим создать свою собственную стену как на Facebook. Для этого нам придётся воспользоваться Facebook Graph API, jQuery, и плагином для шаблонов (template plugin). jQuery.tmpl позволит нам сконвертировать наши посты и создать отдельный HTML код.
Перед тем, как начать, давайте поговорим о Facebook API.
Graph API
Graph - это решение Facebook, которое применяется для интерфейсов. У каждой страницы, которую Вы видите на сайте, есть соответствующее представление, будь то пользователь, фотография, группа, корректировка данных или что-либо еще. API также поддерживает запросы JSONP, что позволяет задействовать jQuery.
В нашем случае, будем использовать два API ключа – для того, чтобы получить все последние посты и для извлечения информации о пользователе (полное имя, аватар и т.д.); Ниже можете увидеть пример:
http://graph.facebook.com/smashmag/posts/
{
"data": [{
"id": "45576747489_10150136051797490",
"from": {
"name": "Smashing Magazine",
"category": "Website",
"id": "45576747489"
},
"message": "Creating a sphere with 3D CSS",
"picture": "http://platform.ak.fbcdn..",
"link": "http://bit.ly/epqBBv",
"name": "Creating a sphere with 3D CSS \u2013 Paul Hayes",
"caption": "www.paulrhayes.com",
"description": "A professional slice of newly..",
"icon": "http://photos-d.ak.fbcdn.net/photos..",
"actions": [{
"name": "Share",
"link": "http://www.facebook.com/share.."
}],
"type": "link",
"application": {
"name": "Sendible",
"id": "26065877776"
},
"created_time": 1301325483,
"updated_time": 1301325483,
"likes": {
"data": [{
"name": "Zome Lia",
"id": "100000643422735"
}],
"count": 16
}
}]
}
Ответ JSON содержит информацию о постах Smashing Magazine. Некоторые поля содержат информацию о дате создания/редактирования, количестве комментов, заголовок, описание, тип… И это не предел.
Также нам надо создать дополнительный запрос для извлечения аватарки:
http://graph.facebook.com/smashmag/
{
"id": "45576747489",
"name": "Smashing Magazine",
"picture": "http://profile.ak.fbcdn.net/hp..",
"link": "http://www.facebook.com/smashmag",
"category": "Website",
"likes": 42696,
"website": "http://www.smashingmagazine.com/",
"username": "smashmag",
"company_overview": "Founded in September 2006..",
"mission": "The offical Smashing Magazine pa..!",
"products": "Looking for a web design job? Che.."
}
Теперь мы получили то, что нам нужно.
Шаблоны
Теперь давайте поговорим о шаблоне jQuery. Так как Graph API возвращает валидные JSON данные, то мы можем применить их для шаблонов. Для этого мы должны определить блоки HTML кода.
Сами шаблоны можно поместить между тегом script или обратиться к ним средствами AJAX. В этом уроке мы будем использовать первый вариант.
Каждый шаблон будет иметь следующую форму:
<script id="someID" type="text/x-jquery-tmpl"> <!-- HTML markup coupled with template tags --> </script>
А вот и первый шаблон:
<script id="headingTpl" type="text/x-jquery-tmpl">
<h1>${name}<span>on Facebook</span></h1>
</script>
${} тег получает изменённое имя свойства объекта, переданного в метод tmpl().
Другой шаблон, который служит для отображения постов, будет более сложным:
<script id="feedTpl" type="text/x-jquery-tmpl">
<li>
<img src="/${from.picture}" />
<div>
<h2><a href="http://www.facebook.com/profile.php?id=${from.id}" target="_blank">${from.name}</a></h2>
<p>{{html message}}</p>
{{if type == "link" }}
<div>
{{if picture}}
<img src="/${picture}" />
{{/if}}
<div>
<p><a href="/${link}" target="_blank">${name}</a></p>
<p>${caption}</p>
<p>${description}</p>
</div>
</div>
{{/if}}
</div>
<p>${created_time} ·
{{if comments}}
${comments.count} Comment{{if comments.count>1}}s{{/if}}
{{else}}
0 Comments
{{/if}} ·
{{if likes}}
${likes.count} Like{{if likes.count>1}}s{{/if}}
{{else}}
0 Likes
{{/if}}
</p>
</li>
</script>
Внутри тегов мы можем использовать JavaScript выражения. Это особенно полезно, когда нам надо использовать выражения {{if}}, чтобы проверить наличие комментариев.
А вот наш HTML документ:
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Making a Custom Facebook Wall with jQuery | Tutorialzine Demo</title>
<link rel="stylesheet" type="text/css" href="/css/styles.css" />
</head>
<body>
<div id="page">
<div id="wall"></div>
</div>
<!-- jQuery templates. Not rendered by the browser. Notice the type attributes -->
<script id="headingTpl" type="text/x-jquery-tmpl">
<h1>${name}<span>on Facebook</span></h1>
</script>
<script id="feedTpl" type="text/x-jquery-tmpl">
<li>
<img src="/${from.picture}" class="avatar" />
<div class="status">
<h2><a href="http://www.facebook.com/profile.php?id=${from.id}" target="_blank">${from.name}</a></h2>
<p class="message">{{html message}}</p>
{{if type == "link" }}
<div class="attachment">
{{if picture}}
<img class="picture" src="/${picture}" />
{{/if}}
<div class="attachment-data">
<p class="name"><a href="/${link}" target="_blank">${name}</a></p>
<p class="caption">${caption}</p>
<p class="description">${description}</p>
</div>
</div>
{{/if}}
</div>
<p class="meta">${created_time} ·
{{if comments}}
${comments.count} Comment{{if comments.count>1}}s{{/if}}
{{else}}
0 Comments
{{/if}} ·
{{if likes}}
${likes.count} Like{{if likes.count>1}}s{{/if}}
{{else}}
0 Likes
{{/if}}
</p>
</li>
</script>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.1/jquery.min.js"></script>
<script src="/js/jquery.tmpl.min.js"></script>
<script src="/js/script.js"></script>
</body>
</html>
Блок #wall будет динамически взаимодействовать с данными Graph API. В самом низу вы можете увидеть сами шаблоны. За ними я подключаю библиотеку jQuery, jQuery.tmpl плагин и файл script.js, о котором пойдёт речь дальше.
jQuery
Давайте приступим к разработке плагина.
script.js
// Создаём плагин.
(function($){
$.fn.facebookWall = function(options){
options = options || {};
if(!options.id){
throw new Error('You need to provide an user/page id!');
}
// начальные значения:
options = $.extend({
limit: 15 // лимит
},options);
// Graph API URL:
var graphUSER = 'http://graph.facebook.com/'+options.id+'/?fields=name,picture&callback=?',
graphPOSTS = 'http://graph.facebook.com/'+options.id+'/posts/?callback=?&date_format=U&limit='+options.limit;
var wall = this;
$.when($.getJSON(graphUSER),$.getJSON(graphPOSTS)).done(function(user,posts){
// user[0] содержит инфу о пользователе
// posts[0].data содержит инфу о постах;
var fb = {
user : user[0],
posts : []
};
$.each(posts[0].data,function(){
posts feed:
if(this.type != 'link' && this.type!='status'){
return true;
}
// Копируем аватар
// проще генерировать шаблоны:
this.from.picture = fb.user.picture;
// конвертируем время из UNIX timestamp
// в что-то вроде (5 минут назад):
this.created_time = relativeTime(this.created_time*1000);
// конвертируем URL
this.message = urlHyperlinks(this.message);
fb.posts.push(this);
});
$('#headingTpl').tmpl(fb.user).appendTo(wall);
// создаём список для постов:
var ul = $('Мы используем метод $.getJSON для отправки запроса в Graph API. Вы наверное заметили, что у нас нет функции обратного вызова. Это происходит по той причине, что мы получаем все данные одновременно.
Начиная с jQuery 1.5, всем стало известно об отложенных объектах. Наверное вы уже видели конструкции типа $.when(). Это поможет нам достичь желаемого результата (инфа о пользователе и посты получим одновременно).
Рендеринг шаблонов:
$('#headingTpl').tmpl(fb.user).appendTo(wall);
// создаём список для постов:
var ul = $('<ul>').appendTo(wall);
// генерируем шаблоны:
$('#feedTpl').tmpl(fb.posts).appendTo(ul);
Метод tmpl() принимает массив. Теперь давайте применим плагин:
$(document).ready(function(){
// вызываем плагин:
$('#wall').facebookWall({id:'smashmag'});
});
Вот и всё!
Вывод
Итак, вы научились работать с шаблонами и взаимодействовать с Facebook!
Надеюсь, сегодняшний урок был для вас полезен.
Источник: http://feedproxy.google.com/~r/ruseller/CdHX/~3/HZrKp4muKhA/lessons.php
|
В этом уроке мы хотим создать свою собственную стену как на Facebook. Для этого нам придётся воспользоваться Facebook Graph API, jQuery, и плагином для шаблонов (template plugin). jQuery.tmpl |
РэдЛайн, создание сайта, заказать сайт, разработка сайтов, реклама в Интернете, продвижение, маркетинговые исследования, дизайн студия, веб дизайн, раскрутка сайта, создать сайт компании, сделать сайт, создание сайтов, изготовление сайта, обслуживание сайтов, изготовление сайтов, заказать интернет сайт, создать сайт, изготовить сайт, разработка сайта, web студия, создание веб сайта, поддержка сайта, сайт на заказ, сопровождение сайта, дизайн сайта, сайт под ключ, заказ сайта, реклама сайта, хостинг, регистрация доменов, хабаровск, краснодар, москва, комсомольск |
Дайджест новых статей по интернет-маркетингу на ваш email
Новые статьи и публикации
- 2025-12-02 » Когда ошибка молчит: как бессмысленные сообщения ломают пользовательский опыт
- 2025-12-02 » 9 лучших бесплатных фотостоков
- 2025-12-02 » UTM-метки: ключевой инструмент аналитики для маркетолога
- 2025-12-02 » ПромоСтраницы Яндекса: Что такое и для чего служит
- 2025-12-02 » Метатеги для сайта: исчерпывающее руководство по Title, Description, Canonical, Robots и другим тегам
- 2025-11-26 » Оценка эффективности контента: превращаем информационный балласт в рабочий актив
- 2025-11-26 » 10 причин высокого показателя отказов на сайте
- 2025-11-26 » Когда и зачем обновлять структуру сайта
- 2025-11-26 » Скрытые демотиваторы: как мелочи разрушают эффективность команды
- 2025-11-26 » Зачем запускать MVP и как сделать это грамотно?
- 2025-11-20 » Половина российских компаний сократит расходы на транспорт и маркетинг в 2026 году
- 2025-11-20 » Перенос сайта с большим количеством ссылок
- 2025-11-20 » Перелинковка сайта: Что такое и как ее использовать
- 2025-11-20 » Критерии выбора SEO-специалиста и подрядчика для продвижения сайта
- 2025-11-20 » Применение искусственного интеллекта в рекламных агентствах: комплексное исследование трендов 2025 года
- 2025-11-19 » Геозапросы по-новому: как покорить локальное SEO с помощью ИИ
- 2025-11-14 » Консалтинг: сущность и ключевые направления
- 2025-11-14 » Онлайн-формы: универсальный инструмент для сбора обратной связи
- 2025-11-14 » Факторы конверсии органического трафика
- 2025-11-14 » Планирование рекламного бюджета: самостоятельный подход
- 2025-11-14 » Авторизация на сайте: как выбрать решение для удержания клиентов и сохранения продаж
- 2025-11-13 » Эффективные методы стимулирования клиентов к оставлению положительных отзывов
- 2025-11-13 » Налоговая реформа — 2026: грядущие изменения для предпринимателей
- 2025-11-13 » Альтернативы мессенджерам: что выбрать вместо Telegram и WhatsApp
- 2025-11-13 » Маркировка рекламы для начинающих: полное руководство по требованиям ЕРИР
- 2025-11-13 » ИИ не отберет вашу работу — её займет специалист, владеющий искусственным интеллектом
- 2025-10-29 » Как оценить эффективность работы SEO-специалиста: практическое руководство для маркетологов и владельцев бизнеса
- 2025-10-29 » Киберспорт как маркетинговый инструмент: стратегии привлечения геймеров
- 2025-10-29 » Как говорить с аудиторией о сложном
- 2025-10-29 » Что такое доказательства с нулевым разглашением (ZKP) и их роль в блокчейне
Секрет быть несчастным: иметь время занудствовать на тему, счастлив ты или нет Шоу Джордж Бернард - (1856-1950) - английский писатель. В своем творчестве ниспровергал догматизм и предвзятость, традиционность представлений |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.


Мы создаем практически любые сайты от продающих страниц до сложных, высоконагруженных и нестандартных веб приложений! Наши сайты это надежные маркетинговые инструменты для успеха Вашего бизнеса и увеличения вашей прибыли! Мы делаем красивые и максимально эффектные сайты по доступным ценам уже много лет!
Комплексный подход это не просто продвижение сайта, это целый комплекс мероприятий, который определяется целями и задачами поставленными перед сайтом и организацией, которая за этим стоит. Время однобоких методов в продвижении сайтов уже прошло, конкуренция слишком высока, чтобы была возможность расслабиться и получать \ удерживать клиентов из Интернета, просто сделав сайт и не занимаясь им...
Мы оказываем полный комплекс услуг по сопровождению сайта: информационному и техническому обслуживанию и развитию Интернет сайтов.
Контекстная реклама - это эффективный инструмент в интернет маркетинге, целью которого является увеличение продаж. Главный плюс контекстной рекламы заключается в том, что она работает избирательно.