|
Профессиональный веб-дизайн: Введение в современные веб-технологии "3. Создание внешней таблицы. Теперь создайте таблицу с двумя строками. Во второй строке создайте две ячейки - в первую переместите таблицу цифр, а во вторую - таблицу знаков." Как в ячейку <td> поместить таблицу? Таблица же сама состоит из ячеек. Исходя из задания следует, что <td> может быть родителем для <td>, но это противоречит правилам HTML? |
Перспективы и расширения HTML
Canvas
Этот новый HTML-элемент предоставляет API для рисования. В отличие от SVG, Canvas оперирует не объектами (текст, линия, кривая), а точками, т.е. выполнение, например, команды fillRect создаст на холсте нарисованный прямоугольник, но не предоставит нового объекта, аналогичного rect в SVG, которым можно было бы манипулировать при помощи набора свойств и методов DOM, и который мог бы реагировать на внешние события. Зато работа Canvas с точечной графикой более эффективна, чем в SVG. Несколько команд рисования показано в примере 21.1.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Canvas 2D</title>
<style type="text/css">
div {
position: absolute;
top: 50%;
left: 50%;
width: 600px;
height: 400px;
margin: -200px 0 0 -300px;
}
</style>
</head>
<body>
<!--[if IE]><script type="text/javascript" src="excanvas.js"></script><![endif]-->
<script type="text/javascript">
window.onload = function() {
/*получаем ссылку на холст*/
var canvas = document.getElementById('myCanvas');
/*контекст*/
var context = canvas.getContext('2d');
/*создаём градиент*/
var myGradient = context.createLinearGradient(0, 0, 600, 400);
/*добавляем цветовые позиции к градиенту*/
myGradient.addColorStop(0, "green");
myGradient.addColorStop(1, "white");
/*устанавливаем созданный градиент как стиль заливки*/
context.fillStyle = myGradient;
/*заливаем прямоугольную область*/
context.fillRect(0, 0, 600, 400);
/*определяем стиль текста*/
context.font = "bold 50px sans-serif";
/*цвет обводки*/
context.strokeStyle = 'black';
/*толщина линий*/
context.lineWidth = '3.0';
/*цвет заливки*/
context.fillStyle = 'yellow';
/*выравнивание текста*/
context.textAlign = "center";
context.textBaseline = "middle";
/*рисуем обводку текста*/
context.strokeText('Hello, World!', 300, 200);
/*рисуем заливку текста*/
context.fillText('Hello, World!', 300, 200);
}
</script>
<div>
<canvas id="myCanvas" width="600" height="400">
</canvas>
</div>
</body>
</html>
Листинг
21.1.
Рисование при помощи Canvas
В настоящее время элемент Canvas поддерживается большинством популярных браузеров, за исключением IE. Однако, IE поддерживает язык разметки векторной графики VML, который позволяет частично эмулировать Canvas, и для эмуляции создана Javascript-библиотека ExplorerCanvas (см. пример 21.1 - в нём к HTML-странице подключается скрипт excanvas.js ). Таким образом, этот элемент с некоторыми ограничениями использовать можно.
Ссылка на спецификацию: http://www.w3.org/TR/html5/the-canvas-element.html
Хранилище DOM
Ещё один полезный механизм, заложенный в проект спецификации HTML 5 и уже реализованный в IE8, а также в ряде других браузеров - хранилище DOM.
С помощью хранилища DOM, как и с помощью файлов Cookie, веб-разработчики могут сохранять данные на стороне клиента для конкретного сеанса ( sessionStorage ) или специфические данные домена ( localStorage ) в виде пар имя-значение.
Хранилище DOM может предоставить значительно больше дискового пространства, чем файлы Cookie. В Internet Explorer в файлах Cookie можно сохранить только 4 КБ данных. В хранилище DOM в IE8 предоставляется приблизительно 10 МБ для каждой области хранения (в других браузерах - несколько меньше).
С функциональной точки зрения хранилища DOM значительно отличаются от файлов Cookie. Из хранилища DOM значения не передаются на сервер с каждым запросом, как в файлах Cookie, и срок действия данных в локальной области хранения никогда не истекает. В отличие от файлов Cookie в хранилище DOM проще осуществлять доступ к отдельным фрагментам данных с использованием стандартного интерфейса, который приобретает все более широкую поддержку у поставщиков браузеров.
Пример 14.2 иллюстрирует основные приёмы работы с хранилищем.
<!DOCTYPE html>
<html>
<head>
<title>Сохранение сеанса</title>
<script type="text/javascript">
var list;
window.onload = function() {
//сохраняем ссылку на список (она будет использоваться часто)
list = document.getElementById('list');
var StorageSupported = false;
//определяем, поддерживается ли хранилище:
//некоторые браузеры создают исключение при обращении к sessionStorage -
//поэтому помещаем проверку в блок try/catch
try {
if (sessionStorage) StorageSupported = true;
}
catch (e) { }
if (StorageSupported) {
//поддержка есть - сообщим об этом
document.getElementById('msg').innerHTML =
'Ваш браузер ' + 'поддерживает'.fontcolor('green') + ' хранилище сеанса';
//проходим в цикле по всем элементам, уже сохранённым в хранилище (если есть)
for (var n = 0; n < sessionStorage.length; n++) {
var key = sessionStorage.key(n);
//помещаем их ключи и значения в список list
list.options[list.options.length] = new Option(key + ': ' + sessionStorage[key], key);
}
}
else {
//поддержки нет - также сообщаем об этом
document.getElementById('msg').innerHTML =
'Ваш браузер ' + 'не поддерживает'.fontcolor('red') + ' хранилище сеанса';
//получаем ссылку на массив элементов формы
var formElems = document.forms[0].elements;
//и делаем их недоступными (disabled)
for (i = 0; i < formElems.length; i++) {
formElems[i].disabled = 'disabled';
}
}
}
//это событие возникает (если браузер его поддерживает) при изменении в хранилище
document.onstorage = function() {
//опустошаем список
while (list.hasChildNodes()) { list.removeChild(list.firstChild); }
//и воссоздаём его на основе изменившегося хранилища
for (var n = 0; n < sessionStorage.length; n++) {
var key = sessionStorage.key(n);
list.options[list.options.length] = new Option(key + ': ' + sessionStorage[key], key);
}
}
</script>
</head>
<body>
<h1>
Страница 1</h1>
<h2 id="msg">
</h2>
<form action="">
<p>
Здесь вы можете ввести произвольный текст, который будет сохранён в хранилище
сеанса под ключом <code>info1</code>:</p>
<textarea cols="50" rows="5" id="info1" onkeyup="if(value) sessionStorage.setItem('info1', value);"></textarea>
<p>
Здесь вы можете ввести произвольный текст, который будет сохранён в хранилище
сеанса под ключом <code>info2</code>:</p>
<textarea cols="50" rows="5" id="info2" onkeyup="if(value) sessionStorage.setItem('info2', value);"></textarea>
<p>
Здесь вы можете ввести произвольный текст, который будет сохранён в хранилище
сеанса под ключом <code>info3</code>:</p>
<textarea cols="50" rows="5" id="info3" onkeyup="if(value) sessionStorage.setItem('info3', value);"></textarea>
<p>
<label>
Ключи, существующие в хранилище сеанса:<br />
<br />
<select id="list" size="3" style="width: 200px;">
</select>
</label>
<br />
<input type="button" value="Поместить в textarea" onclick="if(list.value)
document.getElementById(list.value).value = sessionStorage[list.value]" />
<input type="button" value="Удалить выделенный"
onclick="if(list.value) sessionStorage.removeItem(list.value);" />
<br />
<input type="button" value="Удалить все" onclick="sessionStorage.clear();" />
<input type="button" value="Обновить список" onclick="document.onstorage()" />
<br />
<br />
<a href="Ext_sessionStorage_page2.htm">Перейти на страницу 2</a></p>
</form>
</body>
</html>
Листинг
21.2.
Сохранение сеанса при помощи механизма sessionStorage
Введите произвольный текст в области ввода. При необходимости нажмите кнопку "Обновить список" (браузер IE8 обрабатывает событие onstorage, остальные - пока нет). Список отображает введённые блоки текста, сохранённые в хранилище сеанса.
Перейдите на страницу 2: а) в той же вкладке; б) в новой вкладке: в) начав новый сеанс (если используется IE8). Проследите в каждом случае: 1) отображаются ли в списке блоки, сохранённые на странице 1; 2) изменится ли список на странице 1, если его изменить на странице 2 (в случае "а" должен).
Откройте код страницы 1 в редакторе и измените везде sessionStorage на localStorage. Запустите изменённую страницу и убедитесь, что данные в локальном хранилище доступны даже после перезапуска браузера.
Пользоваться рассматриваемой технологией следует с осторожностью, поскольку лишь последние версии популярных браузеров её поддерживают. Поэтому на хранилище DOM следует возлагать задачи, связанные с повышением удобства пользователя (например, запоминание состояния страницы), но не с принципиальными моментами, касающимися функционирования приложения.
Ссылки:
http://dev.w3.org/html5/webstorage
http://msdn.microsoft.com/ru-ru/library/cc197062(VS.85).aspx
http://blogs.msdn.com/giorgio/archive/2009/11/29/ie8-and-html-5.aspx