Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
 Аватар для Pepeka
171 / 170 / 36
Регистрация: 15.01.2014
Сообщений: 1,010

Записать в БД число кликов по блоку DIV

08.05.2015, 14:35. Показов 2007. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Друзья!

Помогите с вопросом - нужно писать в БД число кликов по блоку DIV. Ну т.е. нажали блок - скрипт тут же записал в БД значение "+1",увеличил счетчик так сказать. Как на магическом JQ это делается? Ни разу с БД не работал из скриптов, потому прошу помощи. БД на MySQL (Wordpress).
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
08.05.2015, 14:35
Ответы с готовыми решениями:

Как адресоваться к блоку div?
Есть страница сайта http://539687.fdcorp.web.hosting-test.net/index.php?option=com_zoo&view=category&layout=category&Itemid=33 ...

Как обратиться к первому по парядку блоку div?
У меня есть код, примерно следующего типа <div id="block"> <div class="myclass"></div> <div...

Как растянуть фон картинку по блоку DIV
Здравствуйте! Есть такая проблемка... Например блок DIV в ширину на 100% экрана, а в высоту 300 пикселей. Нужно чтоб в высоту картинка...

6
 Аватар для Svid_off
82 / 82 / 38
Регистрация: 15.03.2013
Сообщений: 280
08.05.2015, 15:39
В общих чертах это будет выглядеть так:
- на клик вешается обработчик
- в обработчике помимо прочего посылается пост-запрос на сервер (к какому-нибудь файлу php, типа backend.php)
- в этом файле (backend.php) обработка запроса, чтение из БД, увеличение числа кликов и запись (update) нового числа.

Как-то так.
0
 Аватар для Pepeka
171 / 170 / 36
Регистрация: 15.01.2014
Сообщений: 1,010
08.05.2015, 16:54  [ТС]
Цитата Сообщение от Svid_off Посмотреть сообщение
чтение из БД, увеличение числа кликов и запись (update) нового числа
Ну вот если остальное понятно, и скорее всего осилю, то как раз непосредственное исполнение этой части кода, работа с БД - вызовет у меня наибольшие затруднения. Потому и прошу подсказать, дать версию кода, чтобы уже в ней самостоятельно разбираться, а не читать справочники - что тоже очень полезно, но не эффективно по времени, когда "надо" сделать.
0
 Аватар для Svid_off
82 / 82 / 38
Регистрация: 15.03.2013
Сообщений: 280
08.05.2015, 18:04
Потому и прошу подсказать, дать версию кода, чтобы уже в ней самостоятельно разбираться, а не читать справочники - что тоже очень полезно, но не эффективно по времени, когда "надо" сделать.
Все зависит от того, что у Вас уже есть: есть ли файл (класс, контроллер и т.д.) обрабатывающий аякс-запросы, или нет. Есть ли уже таблица в которой эти клики хранятся или нет, если нет, то что и как Вы в ней собираетесь хранить(только ли число кликов или что еще) и т.д. Трудно дать версию абстрактного кода оторванного от контекста.
1
 Аватар для Pepeka
171 / 170 / 36
Регистрация: 15.01.2014
Сообщений: 1,010
08.05.2015, 18:22  [ТС]
Цитата Сообщение от Svid_off Посмотреть сообщение
Все зависит от того, что у Вас уже есть
Ну а нет ничего. Я же и не знаю, куда двигаться ))

Создам блок DIV, клики по которому надо учитывать... Дальше всё, пока вакуум.

Информация к учёту... Учитывать надо вообще страницы, на которых кликнут соответствующий DIV. То есть, получается нужен список ссылок (или ID страниц), и к каждой ссылке этой относится значение - число кликов по DIV-у на данной конкретной странице. Получается таблица, 2 столбца - список ссылок и число кликов. Всё. Хранение этой таблицы в БД, но можно и в текстовом файле, если это упрощает прогание само по себе. Вид не особо важен, важна сама информация.
0
 Аватар для Svid_off
82 / 82 / 38
Регистрация: 15.03.2013
Сообщений: 280
09.05.2015, 19:55
Лучший ответ Сообщение было отмечено Pepeka как решение

Решение

Вот код в вакууме, минимально работающий, без обработки ошибок, исключений и т.д. просто как направление, куда двигаться:
Итак, у нас есть див:
HTML5
1
<div id="count_me">count_me</div>
вешаем на него обработчик:
JavaScript
1
2
3
4
5
6
            $(function(){
                $('#count_me').bind('click',function(e){
                    e.preventDefault();
                    $.post('server.php',{'action':'count_click','url':document.location.href})
                });
            });
server.php - это путь к файлу, в котором будет происходить обработка нашего аякс-запроса (так что надо будет указать корректный путь).

Файл server.php:

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
$dsn      = 'mysql:host=localhost;dbname=ИМЯ_ВАШЕЙ_БД';
$user     = 'ВАШ_ЛОГИН';
$password = 'ВАШ_ПАРОЛЬ';
$dbh      = new PDO($dsn, $user, $password);
 
if ( isset($_POST['action']) and $_POST['action'] == 'count_click' ) {
    $div_url = filter_input(INPUT_POST, 'url', FILTER_VALIDATE_URL);
    $sql     = "SELECT `div_count` FROM `div_count` WHERE `div_url`=:url";
    $sth     = $dbh->prepare($sql);
    $sth->bindValue(':url', $div_url);
    $sth->execute();
 
    if ( $current_count = $sth->fetch(PDO::FETCH_ASSOC) ) {
        $sql     = "UPDATE `div_count` SET  `div_count`=:count WHERE `div_url`=:url";
        $sth     = $dbh->prepare($sql);
        $sth->bindValue(':url', $div_url);
        $sth->bindValue(':count', ++$current_count['div_count'],PDO::PARAM_INT);
        $sth->execute();
    }
    else {
        $sql     = "INSERT INTO `div_count` (`div_url`, `div_count`) VALUES (:url, :count)";
        $sth     = $dbh->prepare($sql);
        $sth->bindValue(':url', $div_url);
        $sth->bindValue(':count', 1);
        $sth->execute();        
    }
}
То есть, у вас должна быть база данных, в которой должна быть таблица `div_count` с полями div_count и div_url.
Как-то так. Еще раз повторюсь: код - "в вакууме", оставлять его в таком виде никак нельзя
1
 Аватар для Pepeka
171 / 170 / 36
Регистрация: 15.01.2014
Сообщений: 1,010
09.05.2015, 20:48  [ТС]
Цитата Сообщение от Svid_off Посмотреть сообщение
оставлять его в таком виде никак нельзя
Всё, спс! Кода много, направление задано, есть где поковыряться ) Спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
09.05.2015, 20:48
Помогаю со студенческими работами здесь

Присвоить div-блоку атрибут style с параметром display:none
Добрый вечер. Допустим, есть div-блок. У него есть атрибут с параметром: &lt;div style=&quot;display: block;&quot;&gt; Как сделать...

Как назначить свойства блоку div через свойство SetAttribute?
Здравствуйте, уважаемые форумчане! Обращаюсь сюда, потому что возникла проблема: не получается добавить свойства к div элементу. Подскажите...

Заменить число своего атрибута в div, который находится в div с id
Всем привет! Есть HTML-код: &lt;div id=&quot;1&quot;&gt; &lt;div data-num=&quot;124&quot;&gt;&lt;/div&gt; &lt;div id=&quot;2&quot;&gt; &lt;div data-num=&quot;135&quot;&gt;&lt;/div&gt; &lt;div...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
Установка Emscripten SDK (emsdk) и CMake на Windows для сборки C и C++ приложений в WebAssembly (Wasm)
8Observer8 30.01.2026
Чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. Система контроля версиями Git. . .
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru