Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/8: Рейтинг темы: голосов - 8, средняя оценка - 4.88
0 / 0 / 0
Регистрация: 13.09.2012
Сообщений: 47

Требуется динамически менять кнопки

01.02.2017, 23:58. Показов 1592. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Никак не могу сообразить.
Требуется менять имя и id кнопки после нажатия.
Изначально кнопка имеет имя "следующее слово", после нажатия имя должно смениться на "проверить", при следующем нажатии снова должно поменяться на "следующее слово" и так далее.
Удается поменять имя только один раз.
Подскажите как решить проблему.


PHP/HTML
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
28
29
30
31
32
33
34
35
36
37
38
39
<html>
    <head>
        <meta charset = "UTF-8">
        <script src = "http://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
        <script>
            $(document).ready(function()
                {
                    func1();
                });
 
            function func1() {
                $("#next_word").bind("click", function () {
                    var check_word = document.createElement("button");
                    var name_button = document.createTextNode("Проверить");
                    check_word.appendChild(name_button);
                    check_word.setAttribute ('id', 'check_word'); 
                    var button_start_les = document.getElementById("next_word");
                    button_start_les.parentNode.replaceChild(check_word, next_word);    
                    func2();
                }); 
            }
 
            function func2() {
                $("#check_word").bind("click", function () {
                    var next_word = document.createElement("button");
                    var name_button = document.createTextNode("Проверить");
                    next_word.appendChild(name_button);
                    next_word.setAttribute ('id', 'next_word'); 
                    var button_start_les = document.getElementById("check_word");
                    button_start_les.parentNode.replaceChild(next_word, check_word);    
                    func1();
                }); 
            }
        </script>
    </head>
    <body>
        <button id = "next_word">Следующее слово</button>
    </body>
</html>
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.02.2017, 23:58
Ответы с готовыми решениями:

Динамически менять цвет фона у элемента HTML-формы
Имеется html-форма. На ней два элемента: checkbox и edit. если в checkbox стоит галочка, то edit доступен, иначе нет. все это работает...

Нужно динамически менять ширину левого фрейма до нуля
Есть такая тема. Три фрейма: top. левый и правый. Нужно динамически менять ширину левого фрейма до нуля. кнопкой из фрейма top, чтобы...

Как в Netscape динамически менять параметры вызываемого файла?
На основной странице имеется строки: &lt;script language='JavaScript1.2' src='clside.js'&gt;&lt;/script&gt; &lt;script id='gener'...

8
 Аватар для Nikto
156 / 138 / 51
Регистрация: 28.11.2009
Сообщений: 460
Записей в блоге: 14
02.02.2017, 01:06
w432w, а почему бы, вместо создания и удаление элементов, просто не создать 2 кнопки в html, вторую заранее скрыть, и в js при нажатии на первую скрывать её и показывать вторую, при нажатии на вторую скрывать её и показывать первую.
0
Superposition
 Аватар для Padimanskas
950 / 615 / 256
Регистрация: 27.10.2013
Сообщений: 2,083
02.02.2017, 01:21
Цитата Сообщение от w432w Посмотреть сообщение
document.createTextNode("Проверить");
круто)

CSS
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
input[type=checkbox] {
   display: none;
}
 
input[type=checkbox] ~ label:before {
   content: "следующее слово";
}
 
label { 
  -webkit-appearance: push-button;
  -moz-appearance: button; 
  display: inline-block;
  padding: 10px;
}
 
input[type=checkbox]:checked ~ label:before {
   content: "проверить";
}
HTML5
1
2
<input type="checkbox" id="toggle">
<label for="toggle"></label>
https://jsfiddle.net/uauaytcs/

Добавлено через 8 минут
хотя наверное нужно как-то вот так

HTML5
1
<button>следующее слово</button>
JavaScript
1
2
3
4
5
6
7
8
var button = document.querySelector('button');
 
var toggle = true;
 
button.onclick = function(){
toggle = !toggle;
if(!toggle) button.innerHTML = 'проверить'; else button.innerHTML = 'следующее слово';
}
https://jsfiddle.net/uauaytcs/1/
1
0 / 0 / 0
Регистрация: 13.09.2012
Сообщений: 47
02.02.2017, 01:34  [ТС]
Но ведь еще нужно менять id кнопки.

Добавлено через 10 минут
Цитата Сообщение от Nikto Посмотреть сообщение
w432w, а почему бы, вместо создания и удаление элементов, просто не создать 2 кнопки в html, вторую заранее скрыть, и в js при нажатии на первую скрывать её и показывать вторую, при нажатии на вторую скрывать её и показывать первую.
Попробовал такой вариант, но при заходе на страницу и при перезагрузке, сперва отображаются обе кнопки и только потом одна исчезает. Не смотря на то что команда $("#check_word").hide(); в самом начале.
0
Эксперт PHP
 Аватар для Fedor Vlasenko
936 / 693 / 236
Регистрация: 01.02.2015
Сообщений: 1,848
02.02.2017, 01:53
Лучший ответ Сообщение было отмечено w432w как решение

Решение

HTML5
1
<button id="byttonId">следующее слово</button>
JavaScript
1
2
3
4
byttonId.onclick = function() {
  this.clicked = !this.clicked | 0;
  this.innerHTML = this.clicked ? 'проверить' : 'следующее слово';
}
Песочница
0
0 / 0 / 0
Регистрация: 13.09.2012
Сообщений: 47
02.02.2017, 02:28  [ТС]
Нужно менять и имя и id.
0
Эксперт PHP
 Аватар для Fedor Vlasenko
936 / 693 / 236
Регистрация: 01.02.2015
Сообщений: 1,848
02.02.2017, 02:39
w432w, я в своей жизни не видел задач в js при которых стоит менять id
Это говорит о том, что идете не по правильному пути
1
 Аватар для Nikto
156 / 138 / 51
Регистрация: 28.11.2009
Сообщений: 460
Записей в блоге: 14
02.02.2017, 12:37
w432w, я говорил о том, чтобы изначально сделать одну кнопку невидимой. Это можно сделать через display none:
HTML5
1
<button id="id2" style="display: none;" onclick="func2()">2</button>
1
0 / 0 / 0
Регистрация: 13.09.2012
Сообщений: 47
02.02.2017, 20:42  [ТС]
Всем спасибо за помощь!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.02.2017, 20:42
Помогаю со студенческими работами здесь

Менять ссылку в зависимости от нажатой кнопки
Доброго времени суток. Нужно менять адрес iframe в зависимости от нажатой ссылки. В ссылке &lt;a&gt; &lt;/a&gt; содержится скрытый input...

Динамически менять содержимое таблицы в зависимости от нажатия на ячейки
Господа, помогите, пожалуйста, новичку. Нужно в статическом html-файле создать на лету таблицу, заполняя ячейки определенными значениями,...

Менять цвета по нажатию кнопки
Есть 9 divов нужно по нажатию кнопки менять цвет. Однако у меня при нажатии меняются цвета всех divов сразу. &lt;div...

Менять значение кнопки по элементам выпадающего списка
Добрый день! Подскажите, пожалуйста, какой метод можно применить чтобы в зависимости от выбранного значения в выпадающем списке менялось...

Менять ссылку в зависимости от нажатой кнопки
Доброго времени суток. Нужно менять адрес iframe в зависимости от нажатой ссылки. В ссылке &lt;a&gt; &lt;/a&gt; содержится скрытый input...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! в-строка - входное арифметическое выражение в инфиксной(обычной). . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru