Простое приложение для записи заметок
В данном уроке мы сделаем простое приложение на PHP и jQuery, которое будет давать возможность пользователю писать заметки. Заметки будут сохраняться в простых текстовых файлах на сервере. В уроке демонстрируется техника чтения и записи файлов в PHP, изменение размеров области текста с помощью jQuery в зависимости от размера содержания, и простое взаимодействие AJAX.
Разметка HTML
Нам нужно создать обычный документ HTML5. Ниже представлена только важная часть, остальной код можно посмотреть в файле исходников index.php. PHP код размешен в одном файле со структурой для большей наглядности.
<div id="pad"> <h2>Заметка</h2> <textarea id="note"><?php echo $note_content ?></textarea> </div>
Вот и вся разметка, которая нужна для работы нашего приложения. Конечно, мы добавим стили CSS, подключим jQuery и наш скрипт script.js. Обратите внимание, что выражение PHP echo
находится в textarea
. Так выводится последняя сохраненная заметка пользователя.
PHP
Код PHP для нашего примера достаточно простой. Происходит чтение и вывод содержания заметки при загрузке страницы, а когда jQuery посылает запрос AJAX - записываем содержание в файл. Файл записи будет перезаписываться.
$note_name = 'note.txt'; $uniqueNotePerIP = true; if($uniqueNotePerIP){ // Используем адрес IP пользователя для именования файла заметки. // Данная техника полезна в случаях, когда приложение // используют несколько пользователей одновременно. if(isset($_SERVER['HTTP_X_FORWARDED_FOR'])){ $note_name = 'notes/'.$_SERVER['HTTP_X_FORWARDED_FOR'].'.txt'; } else{ $note_name = 'notes/'.$_SERVER['REMOTE_ADDR'].'.txt'; } } if(isset($_SERVER['HTTP_X_REQUESTED_WITH'])){ // Запрос AJAX if(isset($_POST['note'])){ // Записываем файл на диск file_put_contents($note_name, $_POST['note']); echo '{"saved":1}'; } exit; } $note_content = ''; if( file_exists($note_name) ){ $note_content = htmlspecialchars( file_get_contents($note_name) ); }
Обратите внимание на переменную $uniqueNotePerIP. Если она имеет значение true, каждый пользователь будет иметь уникальный файл заметки с именем на основе IP адреса. При значении false, все будут использовать один и тот же файл. В таком случае при одновременном использовании приложения несколькими пользователями файл может поврежден.
jQuery
Работа jQuery в нашем приложении заключается в отслеживании изменений в области ввода текста и отправке запроса AJAX post для index.php, где текст будет записан в файл.
Обычный подход в таких случаях - привязка обработчика к событию keypress. Но иногда такого метода недостаточно, так как пользователь может просто скопировать текст в область ввода, или выбрать предложение от автоматического корректора браузера, или использовать операцию отменить/повторить. В такой ситуации нужно использовать обработчик для другого события - input, которое поддерживается всеми современными браузерами.
$(function(){ var note = $('#note'); var saveTimer, lineHeight = parseInt(note.css('line-height')), minHeight = parseInt(note.css('min-height')), lastHeight = minHeight, newHeight = 0, newLines = 0; var countLinesRegex = new RegExp('\n','g'); // Событие input запускается нажатием клавиш, // копированием и даже операциями отмены/повторения. note.on('input',function(e){ // Очистка таймера предотвращает // сохранение каждого нажатия клавиш clearTimeout(saveTimer); saveTimer = setTimeout(ajaxSaveNote, 2000); // Подсчет количества новых строк newLines = note.val().match(countLinesRegex); if(!newLines){ newLines = []; } // Увеличиваем высоту заметки (если нужно) newHeight = Math.max((newLines.length + 1)*lineHeight, minHeight); // Увеличиваем/уменьшаем высоту только один раз при изменеии if(newHeight != lastHeight){ note.height(newHeight); lastHeight = newHeight; } }).trigger('input'); // Данная строка будет изменять размер заметки при загрузке страницы function ajaxSaveNote(){ // Запускаем запрос AJAX POST для сохранения записи $.post('index.php', { 'note' : note.val() }); } });
Еще одной полезной техникой является подсчет количества строк в тексте и увеличение области ввода текста автоматически, в зависимости от значения свойства CSS line-height.
CSS
В данном разделе мы определяем стили для трех элементов HTML нашего урока. Для формирования фона в виде листочка для заметок используется псевдо-элемент :after. При изменении размера области ввода текста в коде jQuery, нижняя часть автоматически сдвигается вниз.
#pad{ position:relative; width: 374px; margin: 180px auto 40px; } #note{ font: normal 15px 'Courgette', cursive; line-height: 17px; color:#444; background: url('../img/mid.png') repeat-y; display: block; border: none; width: 329px; min-height: 170px; overflow: hidden; resize: none; outline: 0px; padding: 0 10px 0 35px; } #pad h2{ background: url('../img/header.png') no-repeat; overflow: hidden; text-indent: -9999px; height: 69px; position: relative; } #pad:after{ position:absolute; content:''; background:url('../img/footer.png') no-repeat; width:100%; height:40px; }
Для блока #note используется шрифт Courgette из коллекции Google Web Fonts.
Готово!
Источник: http://feedproxy.google.com/~r/ruseller/CdHX/~3/2WR2Jb7QmcE/lessons.php
Дайджест новых статей по интернет-маркетингу на ваш email
Новые статьи и публикации
- 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
- 2024-01-18 » Мифический человеко-DevOps
- 2023-12-28 » Google подвел итоги 2023 года в поиске
- 2023-12-28 » 5 ошибок отдела продаж, из-за которых вы теряете клиентов
- 2023-12-28 » Американский суд признал монополию Google на рынках дистрибуции Android-приложений
- 2023-12-28 » Хостинг-провайдер GoDaddy перестанет оказывать услуги пользователям из России
"Не пытайтесь перехитрить поисковые машины - надежность и доверие ценятся в сфере поискового маркетинга куда больше." |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.