Главная страница статей --> Советы по фотошопу, графике и хитрости в построении php кода

Загрузчик в HTML

Источник: realcoding.net

Рассмотрим типичную ситуацию. Пользователь щелкнул на гиперссылке и браузер начал закачивать запрошенный ресурс. Предположим, что пользователь использует для подключения к Internet модем и эффективная скорость (то есть та скорость, с которой реально пересылаются данные) колеблется где-то около 20Кбит в секунду. Такой показатель для российских телефонных линий - дело обыкновенное. Так же предположим что объем закачиваемого файла равен 200Кб. Нехитрый подсчет показывает, что файл будет загружаться около 80 секунд.

В связи с таким большим временем загрузки возникает опасение, что пользователь не дождется загрузки. Ведь до того, как ресурс прогрузится, пользователь не может определить, идет ли процесс загрузки или же браузер пытается открыть мертвую ссылку.

Однако, начиная с 5 версии Internet Explorer предоставляет механизм, позволяющий частично решить эту проблему. Одно из поведений по умолчанию, поведение download, предоставляет метод startDownload. Методу startDownload передается два аргумента: адрес загружаемого ресурса и указатель на функцию, которая будет вызвана по завершению загрузки ресурса.

Теперь мы можем перехватить нажатие на гиперссылку и вызвать метод startDownload с адресом, указанным в гиперссылке. Одновременно мы можем вывести на страницу некое сообщение, предупреждающее пользователя, что идет загрузка большого файла. По завершении загрузки метод startDownload вызовет указанную функцию, которая и произведет переход на ресурс, указанный в гиперссылке. Данная техника демонстрируется в следующем листинге.

<html>
<
head>
<
title>Пример использования download</title>
<
meta http-equiv=Content-Type content=text/html; charset=windows-1251>
<
style type=text/css>
#loadManager {behavior: url(#default#download);}
</style>
<
script language=jscript>
function
ready_go()
{
location.href = loaderManager.href;
}
</script>
</head>
<body>
<a href=http://webber.ru/ id=loadManager
onclick=this.startDownload(this.href,ok_func);>
</body>
</html>

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



Похожие статьи:
- Делаем свой сайт
- Раздельная обработка одиночного и двойного клика мыши в swing
- Редактирование текстовых элементов
- Немного из истории: Кое-что о WAP
- Stackless Python
- Формы в HTML документах
- Стратегия повышения ссылочной популярности для достижения высоких позиций в поисковых системах
- Скрипт управления деревом
- Как использовать Javascript файл из ресурсов
- Переменные среды CGI
- Keywords для начинающих
- Использование XML/XSL для публикации в Web


Оглавление | Обсудить на форуме | Главная страница сайта | Карта сайта |

Контакты
Редакция:
[0.001]