Создание стены 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-04-17 » 23 сервиса для эффективного экспресс-аудита любого сайта
- 2024-04-08 » Яндекс переходит на новую версию Wordstat
- 2024-04-08 » Яндекс интегрировал в свой облачный сервис эмпатичную нейросеть
- 2024-04-08 » Новая версия нейросети Claude превзошла по мощности аналоги Google и OpenAI
- 2024-04-08 » Как пользоваться GPT 4 и Claude бесплатно и без VPN
- 2024-03-13 » Стратегии SEO на 2024 год
- 2024-03-13 » Как использовать анимацию с помощью JavaScript-библиотеки GSAP
- 2024-03-13 » Использование GSAP 3 для веб-анимации
- 2024-03-13 » Cогласование топографической съёмки с эксплуатирующими организациями
- 2024-02-19 » Теряются лиды? Как настроить сквозную аналитику
- 2024-02-17 » Мерч и IT: на что обратить внимание в 2024 году
- 2024-02-16 » Копируем с RSync: основные примеры синхронизации файлов
- 2024-02-15 » Лучшие noCode AI платформы для создания диалоговых ботов
- 2024-02-14 » Факторы ранжирования Google 2024 — исследование Semrush
- 2024-02-12 » Перенос сайта на другой хостинг
- 2024-02-05 » В России сформирован реестр хостинг-провайдеров
- 2024-02-04 » Использование SSH для подключения к удаленному серверу Ubuntu
- 2024-02-03 » Подключаемся к серверу за NAT при помощи туннеля SSH. Простая и понятная инструкция
- 2024-02-02 » Настройка CI/CD для Gitlab-репозитория: схемы и гайд по шагам
- 2024-02-01 » GitLab CI Pipeline. Запуск сценария через SSH на удаленном сервере
- 2024-01-29 » Introduction to GitLab’s CI/CD for Continuous Deployments
- 2024-01-26 » Настройка GitLab CI/CD
- 2024-01-25 » Установка shell gitlab runner
- 2024-01-25 » Установка и регистрация gitlab-runner в docker контейнере
- 2024-01-25 » Переменные Gitlab-Ci
- 2024-01-25 » Настройка CI/CD в GitLab для синхронизации проекта с веб-серверами
- 2024-01-25 » Копирование файлов scp
- 2024-01-21 » Бездепозитные бонусы от казино: обзор условий и правил использования
- 2024-01-18 » Современная обработка ошибок в PHP
- 2024-01-18 » Пример шаблона проектирования MVC в PHP
Одного яйца два раза не высидишь. К. Прутков |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.