• Главная»
  • Уроки»
  • PHP»
  • Автозаполнение полей с использованием PHP, MySQL, jQuery и XML

Автозаполнение полей с использованием PHP, MySQL, jQuery и XML

В данном уроке мы сделаем системы автозаполнения полей для сайта. Данные могут располагаться  в различных источниках - непосредственно в коде JavaScript, в базе данных или в XML файле.

demosourse

 

Шаг 1. Разметка HTML

index.html

<!DOCTYPE html>
<html lang="ru" >
    <head>
        <meta charset="utf-8" />
        <title>Автозаполненние с помощью PHP, jQuery, MySQL и XML | Материалы сайта RUSELLER.COM</title>

        <link href="css/jquery.autocomplete.css" rel="stylesheet" type="text/css" />
        <link href="css/main.css" rel="stylesheet" type="text/css" />
        <script type="text/javascript" src="js/jquery-1.5.2.min.js"></script>
        <script type="text/javascript" src="js/jquery.autocomplete.pack.js"></script>
        <script type="text/javascript" src="js/script.js"></script>
    </head>
    <body>
        <div class="container">
            <form action="#">
                <p><label>Месяц:</label> <input id="month" type="text" autocomplete="off"></p>
                <p><label>Год:</label> <input id="year" type="text" autocomplete="off"></p>
                <p><label>Страна:</label> <input id="country" type="text" autocomplete="off"></p>
            </form>
        </div>
        <footer>
            <h2>Автозаполненние с помощью PHP, jQuery, MySQL и XML</h2>
            <a href="http://www.ruseller.com" class="stuts" target="_blank">Материалы сайта <span>RUSELLER.COM</span></a>
        </footer>
    </body>
</html>

Разметка для демонстрационной страницы достаточна проста и очевидна.

 

Шаг 2. CSS

Зададим стили для формирования внешнего вида нашего кода.

css/main.css

*{
    margin:0;
    padding:0;
}

body {
    background-repeat:no-repeat;
    background-color:#bababa;
    background-image: -webkit-radial-gradient(600px 200px, circle, #eee, #bababa 40%);
    background-image: -moz-radial-gradient(600px 200px, circle, #eee, #bababa 40%);
    background-image: -o-radial-gradient(600px 200px, circle, #eee, #bababa 40%);
    background-image: radial-gradient(600px 200px, circle, #eee, #bababa 40%);
    color:#fff;
    font:14px/1.3 Arial,sans-serif;
    min-height:600px;
}

footer {
    background-color:#212121;
    bottom:0;
    box-shadow: 0 -1px 2px #111111;
    display:block;
    height:70px;
    left:0;
    position:fixed;
    width:100%;
    z-index:100;
}

footer h2{
    font-size:22px;
    font-weight:normal;
    left:50%;
    margin-left:-400px;
    padding:10px 0;
    position:absolute;
    width:350px;
}

footer a.stuts,a.stuts:visited{
    border:none;
    text-decoration:none;
    color:#fcfcfc;
    font-size:14px;
    left:50%;
    line-height:31px;
    margin:20px 0 0 110px;
    position:absolute;
    top:0;
}

footer .stuts span {
    font-size:22px;
    font-weight:bold;
    margin-left:5px;
}

.container {
    border:3px #111 solid;
    color:#000;
    margin:20px auto;
    padding:20px;
    position:relative;
    text-align:center;
    width:300px;

    border-radius:15px;
    -moz-border-radius:15px;
    -webkit-border-radius:15px;
}

.ac_results  {
    border: solid 1px #E5E5E5;
    color:#000;

    border-radius:0 0 5px 5px;
    -moz-border-radius:0 0 5px 5px;
    -webkit-border-radius:0 0 5px 5px;
}
.ac_over {
    background-color:#444;
}

form p {
    margin-bottom:5px;
    text-align:right;
}

form input { 
    background-color: #FFFFFF;
    background: -moz-linear-gradient(top, #FFFFFF, #EEEEEE 1px, #FFFFFF 25px);
    background: -webkit-gradient(linear, left top, left 25, from(#FFFFFF), color-stop(4%, #EEEEEE), to(#FFFFFF));
    border: solid 1px #E5E5E5;
    font-size:14px;
    outline: 0;
    padding: 9px;
    width: 180px;

    border-radius:5px;
    -moz-border-radius:5px;
    -webkit-border-radius:5px;

    box-shadow: rgba(0,0,0, 0.1) 0px 0px 8px;
    -moz-box-shadow: rgba(0,0,0, 0.1) 0px 0px 8px;
    -webkit-box-shadow: rgba(0,0,0, 0.1) 0px 0px 8px;
}

form  input:hover, form  input:focus { 
    border-color: #C9C9C9;

    box-shadow: rgba(0,0,0, 0.5) 0px 0px 8px;
    -moz-box-shadow: rgba(0,0,0, 0.5) 0px 0px 8px;
    -webkit-box-shadow: rgba(0,0,0, 0.5) 0px 0px 8px;
}

В пакете с исходниками присутствуют дополнительные файлы CSS:

css/jquery.autocomplete.css + css/indicator.gif

Оба файла генерируются при формировании пакете с плагином jQuery Аutocomplete при заполнении формы на сайте jQuery. В нашем проекте они используются как есть без изменений.

 

Шаг 3. JavaScript

Теперь создадим код, который будет выполнять автозаполнение полей формы.

js/script.js

$(function(){

    $('#month').autocomplete(['Январь', 'Февраль', 'Март', 'Апрель', 'Май', 'Июнь', 'Июль', 'Август', 'Сентябрь', 'Октябрь', 'Ноябрь', 'Декабрь'], {
        width: 200,
        max: 3
    });

    $('#year').autocomplete('data.php?mode=xml', {
        width: 200,
        max: 5
    });

    $('#country').autocomplete('data.php?mode=sql', {
        width: 200,
        max: 5
    });

});

Мы используем плагин jQuery  Autocomplete. В первом случае задаются значения непосредственно в коде JavaScript. Для второго и третьего варианта используется PHP файл (определяются два разных источника данных - XML и SQL). В пакете с исходниками также включены два других файла JavaScript:

js/jquery-1.5.2.min.js + js/jquery.autocomplete.pack.js

Это сама библиотека jQuery и плагин Autocomplete.

 

Шаг 4. SQL

Нужно подготовить нашу базу данных - создать в ней таблицу с информацией для автозаполнения. Используем следующие запросы:

CREATE TABLE `s85_countries` (
  `country_code` varchar(2) NOT NULL,
  `country_name` varchar(255) NOT NULL,
  PRIMARY KEY  (`country_code`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8;

INSERT INTO `s85_countries` (`country_code`, `country_name`) VALUES 
('AR', 'Аргентина'),
('AU', 'Австралия'),
('BR', 'Бразилия'),
('CA', 'Канада'),
('CN', 'Китай'),
('IN', 'Индия'),
('KZ', 'Казахстан'),
('RU', 'Россия'),
('SD', 'Судан'),
('US', 'США');

Код запросов содержится в пакете с исходниками.

 

Шаг 5. PHP

Теперь формируем код, который будет возвращать данные для плагина Autocomplete:

data.php

<?php

if (version_compare(phpversion(), "5.3.0", ">=")  == 1)
  error_reporting(E_ALL & ~E_NOTICE & ~E_DEPRECATED);
else
  error_reporting(E_ALL & ~E_NOTICE); 

require_once('classes/CMySQL.php');

$sParam = $GLOBALS['MySQL']->escape($_GET['q']); // Выход по чтению внешних данных
if (! $sParam) exit;

switch ($_GET['mode']) {
    case 'xml': // Используем XML как источник данных
        $aValues = $aIndexes = array();
        $sFileData = file_get_contents('data.xml'); // Читаем содержимое
        $oXmlParser = xml_parser_create('UTF-8');
        xml_parse_into_struct($oXmlParser, $sFileData, $aValues, $aIndexes);
        xml_parser_free( $oXmlParser );

        $aTagIndexes = $aIndexes['ITEM'];
        if (count($aTagIndexes) <= 0) exit;
        foreach($aTagIndexes as $iTagIndex) {
            $sValue = $aValues[$iTagIndex]['value'];
            if (strpos($sValue, $sParam) !== false) {
                echo $sValue . "\n";
            }
        }
        break;
    case 'sql': // Используем базу данных как источник данных
        $sRequest = "SELECT `country_name` FROM `s85_countries` WHERE `country_name` LIKE '%{$sParam}%' ORDER BY `country_code`";
        $aItemInfo = $GLOBALS['MySQL']->getAll($sRequest);
        foreach ($aItemInfo as $aValues) {
            echo $aValues['country_name'] . "\n";
        }
        break;
}

Результат фильтруется с помощью входного параметра $_GET['q'] из активного текстового поля (в которое что-то начали вводить). Скрипт выдает все подходящие записи. Также мы используем другой файл:

classes/CMySQL.php

Это класс для работы с базой данных (очень удобный). В его конструкторе нужно установить параметры для соединения с базой данных:

        $this->sDbName = '_ИМЯ_БАЗЫ_ДАННЫХ_';
        $this->sDbUser = '_ИМЯ_ПОЛЬЗОВАТЕЛЕЯ_';
        $this->sDbPass = '_ПАРОЛЬ_';

 

Шаг 6. XML

А вот так выглядит файл XML с данным для автозаполнения:

<?xml version="1.0"?>
<items>
    <item>1991</item>
    <item>1990</item>
    <item>1991</item>
    <item>1992</item>
    <item>1993</item>
    <item>1994</item>
    <item>1995</item>
    <item>1996</item>
    <item>1997</item>
    <item>1998</item>
    <item>1999</item>
    <item>2000</item>
    <item>2001</item>
    <item>2002</item>
    <item>2003</item>
    <item>2004</item>
    <item>2005</item>
    <item>2006</item>
    <item>2007</item>
    <item>2008</item>
    <item>2009</item>
    <item>2010</item>
    <item>2011</item>
    <item>2012</item>
    <item>2013</item>
    <item>2014</item>
    <item>2015</item>
</items>

Данный урок подготовлен для вас командой сайта ruseller.com
Источник урока: www.script-tutorials.com/autocomplete-with-php-jquery-mysql-and-xml/
Перевел: Сергей Фастунов
Урок создан: 3 Января 2012
Просмотров: 84523
Правила перепечатки


5 последних уроков рубрики "PHP"

  • Фильтрация данных с помощью zend-filter

    Когда речь идёт о безопасности веб-сайта, то фраза "фильтруйте всё, экранируйте всё" всегда будет актуальна. Сегодня поговорим о фильтрации данных.

  • Контекстное экранирование с помощью zend-escaper

    Обеспечение безопасности веб-сайта — это не только защита от SQL инъекций, но и протекция от межсайтового скриптинга (XSS), межсайтовой подделки запросов (CSRF) и от других видов атак. В частности, вам нужно очень осторожно подходить к формированию HTML, CSS и JavaScript кода.

  • Подключение Zend модулей к Expressive

    Expressive 2 поддерживает возможность подключения других ZF компонент по специальной схеме. Не всем нравится данное решение. В этой статье мы расскажем как улучшили процесс подключение нескольких модулей.

  • Совет: отправка информации в Google Analytics через API

    Предположим, что вам необходимо отправить какую-то информацию в Google Analytics из серверного скрипта. Как это сделать. Ответ в этой заметке.

  • Подборка PHP песочниц

    Подборка из нескольких видов PHP песочниц. На некоторых вы в режиме online сможете потестить свой код, но есть так же решения, которые можно внедрить на свой сайт.

^ Наверх ^