DataLife Engine > Версия для печати > Блокнот для сайта

Блокнот для сайта — простое приложение на PHP и JQuery, которое позволяет пользователям писать заметки. Все записи будут сохранены в текстовые файлы на сервере.

Шаг 1. HTML

Для начала рассмотрим разметку. Для этого создадим обычный документ HTML5, Ниже представлена только важная часть, остальной код можно посмотреть в файле исходников index.php.


        

Заметка


Как вы заметили разметка не сложная, конечно, мы добавим стили CSS, подключим jQuery и наш скрипт script.js. Обратите внимание, что выражение phpecho находится в textarea.

Шаг 2. CSS

Для формирования фона в виде листочка для заметок используется псевдо-элемент :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;
}

Шаг 3. 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, все будут использовать один и тот же файл.

Шаг 4. jQuery

Работа jQuery в данном приложении заключается в отслеживании изменений в области ввода текста и отправке запроса AJAX post для index.php, где текст будет записан в файл.

$(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() });
        }
});

Обычный подход в таких случаях — привязка обработчика к событию keypress. Но иногда такого метода недостаточно, так как пользователь может просто скопировать текст в область ввода, или выбрать предложение от автоматического корректора браузера, или использовать операцию отменить/повторить.

Вот и все. Готово!