Ajax, php и sql

У меня есть список элементов на моей странице из таблицы БД Я пытаюсь изменить глификон, когда установлен флажок

<div  class = "div1">
<span  id = ".<?php echo $row['id']; ?>" style = "color:black;" class = "glyphicon glyphicon-eye-open"> </span>
</div>

это сценарий вверху моей страницы:

<script>
$(document).ready(function(){
    $(".div1").click(function(){
        $(".div1").load("clicked.php");
    });
});
</script>

clicked.php выглядит так:

<span  id = "<?php echo $row['id']; ?>" style = "color:black;" class = "glyphicon glyphicon-ok"> </span>

Проблема заключается в том, что когда я нажимаю на один элемент - все элементы меняют глификоны

Что я делаю неправильно?

Поскольку вы селектор jquery, вы должны выбрать элемент id.

lighter 03.10.2018 10:27

@lighter Его селектор прав.

Praveen Kumar Purushothaman 03.10.2018 10:28
$(this).load("clicked.php");: ограничьте объем вашего изменения элементом, по которому щелкнули мышью.
jeroen 03.10.2018 10:28

Замените $(".div1").load("clicked.php"); на $(this).load("clicked.php"); и сообщите нам, работает ли он.

Praveen Kumar Purushothaman 03.10.2018 10:28

Для этого вам не нужно загружать новый фрагмент HTML с сервера, все, что вам нужно сделать, это изменить промежутки class, чтобы удалить glyphicon-eye-open и заменить его на glyphicon-ok.

RiggsFolly 03.10.2018 10:30

@PraveenKumarPurushothaman & jeroen Это сработало как по волшебству !!!!! Спасибо!!!!!

Amit 03.10.2018 10:35

@Amit Я добавил это как ответ. Не стесняйтесь принять его, нажав на кнопку с галочкой через 3 минуты.

Praveen Kumar Purushothaman 03.10.2018 10:38

Спасибо, как я могу сделать следующий щелчок обратным к первому классу?

Amit 03.10.2018 10:50
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
8
51
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Вам просто нужно удалить и добавить новый класс:

$(document).ready(function(){
    $(".div1").click(function(){
        $(this).children('span').removeClass('glyphicon-eye-open');
        $(this).children('span').addClass('glyphicon-ok');

        //Here you can add ajax call

    });
});
Ответ принят как подходящий

Нет необходимости полностью идти к серверу, чтобы получить новый диапазон, когда все, что вы делаете, - это удаление класса и добавление нового класса в диапазон.

Также при использовании правильного прицела $(this) остановит его влияние на все ваши элементы div1.

<script>
$(document).ready(function(){
    $(".div1").click(function(){
        //$(".div1").load("clicked.php");
        $(this).children('span').removeClass('glyphicon-eye-open');
        $(this).children('span').addClass('glyphicon-ok');
    });
});
</script>

И чтобы код переключался с одного на другой при каждом щелчке

<script>
    $(document).ready(function(){
        $(".div1").click(function(){
            if ( $(this).children('span').hasClass('glyphicon-ok') ) {
                $(this).children('span').removeClass('glyphicon-ok');
                $(this).children('span').addClass('glyphicon-eye-open');
            } else {
                $(this).children('span').removeClass('glyphicon-eye-open');
                $(this).children('span').addClass('glyphicon-ok');
            }
        });
    });
    </script>

Другие вопросы по теме