Создание стены 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
Дайджест новых статей по интернет-маркетингу на ваш email
Новые статьи и публикации
- 2024-11-26 » Капитан грузового судна, или Как начать использовать Docker в своих проектах
- 2024-11-26 » Обеспечение безопасности ваших веб-приложений с помощью PHP OOP и PDO
- 2024-11-22 » Ошибки в Яндекс Вебмастере: как найти и исправить
- 2024-11-22 » Ошибки в Яндекс Вебмастере: как найти и исправить
- 2024-11-15 » Перенос сайта на WordPress с одного домена на другой
- 2024-11-08 » OSPanel 6: быстрый старт
- 2024-11-08 » Как установить PhpMyAdmin в Open Server Panel
- 2024-09-30 » Как быстро запустить Laravel на Windows
- 2024-09-25 » Next.js
- 2024-09-05 » OpenAI рассказал, как запретить ChatGPT использовать содержимое сайта для обучения
- 2024-08-28 » Чек-лист: как увеличить конверсию интернет-магазина на примере спортпита
- 2024-08-01 » WebSocket
- 2024-07-26 » Интеграция с Яндекс Еда
- 2024-07-26 » Интеграция с Эквайринг
- 2024-07-26 » Интеграция с СДЕК
- 2024-07-26 » Интеграция с Битрикс-24
- 2024-07-26 » Интеграция с Travelline
- 2024-07-26 » Интеграция с Iiko
- 2024-07-26 » Интеграция с Delivery Club
- 2024-07-26 » Интеграция с CRM
- 2024-07-26 » Интеграция с 1C-Бухгалтерия
- 2024-07-24 » Что такое сторителлинг: техники и примеры
- 2024-07-17 » Ошибка 404: что это такое и как ее использовать для бизнеса
- 2024-07-03 » Размещайте прайс-листы на FarPost.ru и продавайте товары быстро и выгодно
- 2024-07-01 » Профилирование кода в PHP
- 2024-06-28 » Изучаем ABC/XYZ-анализ: что это такое и какие решения с помощью него принимают
- 2024-06-17 » Зачем вам знать потребности клиента
- 2024-06-11 » Что нового в работе Яндекс Метрики: полный обзор обновления
- 2024-06-11 » Поведенческие факторы ранжирования в Яндексе
- 2024-06-11 » Скорость загрузки сайта: почему это важно и как влияет на ранжирование
Великие умы обсуждают идеи, средние - обсуждают поступки, а малые - людей Индийская пословица |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.