JavaScript. Подробное руководство, 6-е издание
Шрифт:
Пример 22.4. Модуль поиска на сайте Twitter с помощью метода postMessage
<!DOCTYPE html>
<! —
Это модуль поиска на сайте Twitter. Модуль можно подключить к любой странице внутри элемента <iframe> и запросить его выполнить поиск, отправив ему строку запроса с помощью метода postMessage. Поскольку
модуль подключается в элементе <iframe>, а не <script>, он не сможет получить доступ к содержимому вмещающего документа.
– ->
<html>
<head>
<style>body { font: 9pt sans-serif: }</style>
<!-- Подключить библиотеку jQuery ради ее утилиты jQuery.getJSON -->
<script src=" http://code.jquery.com/jquery-1.4.4.min.js"/></script >
<script>
// Можно было бы просто использовать свойство window.onmessage,
// но некоторые старые броузеры (такие как Firefox 3) не поддерживают его,
// поэтому обработчик устанавливается таким способом,
if (window.addEventListener)
window.addEventListener("message", handleMessage, false);
else
window.attachEvent("onmessage", handleMessage); // Для IE8
function handleMessage(e) {
// Нас не волнует происхождение документа, отправившего сообщение:
// мы готовы выполнить поиск на сайте Twitter для любой страницы.
// Однако сообщение должно поступить от окна, вмещающего этот модуль,
if (е.source !== window.parent) return;
var searchterm = e.data; // Это фраза, которую требуется отыскать
// С помощью утилит поддержки Ajax из библиотеки jQuery и прикладного
// интерфейса Twitter отыскать сообщения, соответствующие фразе.
jQuery.getJS0N(" http://search.twitter.com/search.json?callback= ?",
{ q: searchterm },
function(data) { //
Вызывается с результатами запроса
var tweets = data.results;
// Создать HTML-документ для отображения результатов
var escaped = searchterm.replace("<", "<”);
var html = "<h2>" + escaped + "</h2>";
if (tweets.length == 0) {
html += "No tweets found";
}
else {
html += "<dl>"; // <dl> list of
results
for(var і = 0; і < tweets.length; i++) {
var tweet = tweets[i];
var text = tweet.text;
var from = tweet.from_user;
var tweeturl = " http://twitter.eom/#!/ " + from +
"/status/" + tweet.id_str;
html += "<dt><a target='_blank‘ href="#"text_code"> tweeturl + "'>" + tweet.from_user +
"</a></dt><dd>" + tweet.text + "</dd>";
}
html += "</dl>";
}
// Вставить документ в <iframe>
document.body.innerHTML = html;
});
}
$(function {
// Сообщить вмещающему документу, что модуль готов к поиску. Вмещающий документ
// не может отправлять модулю сообщения до получения этого сообщения, потому что
// модуль еще не готов принимать сообщения. Вмещающий документ может просто
// дождаться события onload, чтобы определить момент, кода будут загружены
Поделиться:
Популярные книги
Наследство Карны
3. Книга Дины
Проза:
современная проза
5.00
рейтинг книги
Камень. Книга восьмая
8. Камень
Фантастика:
фэнтези
боевая фантастика
7.00
рейтинг книги
Лекарь Империи 10
10. Лекарь Империи
Фантастика:
городское фэнтези
боевая фантастика
аниме
попаданцы
5.00
рейтинг книги
Изгой Проклятого Клана. Том 6
6. Изгой
Фантастика:
аниме
фэнтези
фантастика: прочее
попаданцы
5.00
рейтинг книги
Газлайтер. Том 29
29. История Телепата
Фантастика:
боевая фантастика
попаданцы
аниме
5.00
рейтинг книги
Бастард
1. Династия
Фантастика:
попаданцы
аниме
фэнтези
5.00
рейтинг книги
Мужчина не моей мечты
1. Мужчина не моей мечты
Любовные романы:
любовно-фантастические романы
8.30
рейтинг книги
Оживший камень
1. Артефактор
Фантастика:
городское фэнтези
попаданцы
аниме
5.00
рейтинг книги
Врубель
Жизнь в искусстве
Документальная литература:
биографии и мемуары
5.00
рейтинг книги
Вампир. Английская готика. XIX век
Фантастика:
ужасы и мистика
7.67
рейтинг книги
Города в полете
Фантастика:
космическая фантастика
4.25
рейтинг книги
Вернувшийся: Посол. Том IV
4. Вернувшийся
Фантастика:
космическая фантастика
киберпанк
5.00
рейтинг книги
Афганский рубеж 2
2. Рубеж
Фантастика:
попаданцы
альтернативная история
5.00
рейтинг книги
Кодекс Охотника. Книга V
5. Кодекс Охотника
Фантастика:
фэнтези
попаданцы
аниме
4.50