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

Form action="" не работает в хроме и опере при onClick

27.07.2017, 21:12. Показов 956. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток знатокам!
Столкнулся с проблемой, которая не даёт реализовать отправку данных через:
HTML5
1
<form action="">
в браузерах хром и опера. В мозиле и IE работает.

Код: (здесь при нажатии на кнопку срабатывает скрипт js, и включается таймер, но так же должен состоятся переход на другую страницу save.php)
HTML5
1
2
3
4
5
6
7
8
9
10
11
<div id="fomrhunting" >
  <form id="farm" action="save.php" method="post" enctype="multipart/form-data">
    <img src="img/hunting.gif" width="150" align="left">
    <div class="submit">
      <input type="text" name="balans" value="1" /><br> 
      <input id="timerhunting" type="submit" value="Отправиться на охоту" name="submit" onClick=startTimerhunting('my_timerhunting',1) >
    </div>                      
    <div class="timer"><span id="my_timerhunting">00:00:10</span></div> 
  </form>
  <script type="text/javascript" src="js/timerhunting.js"></script>
</div>
Код: (с помощью этого скрипта включается таймер и отключается кнопка на время таймера)
JavaScript
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
(function() {
    function getElem_Time(outElem) {
        var arr = outElem.innerHTML.split(':')
        return 1000*(3600*(+arr[0])+60*(+arr[1])+(+arr[2]));
    }
    function two_dig (t) {
        return  (parseInt(t)/100).toFixed(2).toString().split('.')[1];
    }
    function getHH_MM_SS(sek) {
        return two_dig (sek/3600)+  ':' + two_dig ((sek/60)%60)+ ':' + two_dig (sek%60);
    }
    var timerId;        // ID setInterval
    var firstSaveVal;   // Тут сохраняем начальное значение Time из элемента;
    var  endDate     =  localStorage.endDate;
    startTimerberries = function(sel,test){  //test == 1 при запуске по кнопке и == 0 при автозапуске на новой странице, 3 - сброс;
        var outElem = document.getElementById(sel); //объект вывода/ввода цифр
        clearInterval(timerId);
        if(!firstSaveVal)firstSaveVal = outElem.innerHTML;
        if(!endDate &&!test) return false; //Aвтозапуск на новой странице;
        var deltaT = getElem_Time(outElem);
        if(test){
            document.getElementById("timerberries").disabled = true; //запрет на кнопку
            document.getElementById("timerhunting").disabled = true;
            outElem.innerHTML = firstSaveVal;
            deltaT = getElem_Time(outElem);
            delete localStorage.endDate;
            endDate = localStorage.endDate;
        }
        var thisTime = +new Date();
        if(!endDate){
            var timeEnd = thisTime + deltaT;
            localStorage.endDate = sel+','+ timeEnd;
        }
        if(endDate &&!test){
            var arr = endDate.split(',');
            var outElem = document.getElementById(arr[0]);
            var timeEnd = +arr[1];
            document.getElementById("timerberries").disabled = true; //запрет на кнопку
            document.getElementById("timerhunting").disabled = true;
        }
        function setOutTime(){
            if(+new Date()>=timeEnd){
                clearInterval(timerId);
                outElem.innerHTML='00:00:00';
                document.getElementById("timerberries").disabled = false; //разрешение на кнопку
                document.getElementById("timerhunting").disabled = false;
                delete localStorage.endDate;
                return;
            }
            var timeToFinish = parseInt((timeEnd - +new Date())/1000);
            outElem.innerHTML = getHH_MM_SS(timeToFinish);
        }  
        setOutTime();
        timerId = setInterval(setOutTime,1000);
    }
    startTimerberries("my_timerberries",0); //Aвтозапуск на новой странице с проверкой сохранненого в Storage(если нет - return);
    window.onfocus =   function (){startTimerberries("my_timerberries",0); } //При возврате на вкладку, бывшую неактивной
}());
Когда я убираю
HTML5
1
onClick=startTimerhunting('my_timerhunting',1)
, то
HTML5
1
<form action="">
срабатывает, похоже на какой то конфликт "интересов" между php и js.
Прошу помощи в решении проблемы.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
27.07.2017, 21:12
Ответы с готовыми решениями:

Form action="" не работает в хроме и опере
Доброго времени суток знатокам! Столкнулся с проблемой, которая не даёт реализовать отправку данных через: &lt;form...

Почему form action обращается к action_page.php, если в файле ему уже указан другой form action?
&lt;form action=&quot;login.php&quot; method=&quot;post&quot; class=&quot;form-horizontal&quot;&gt; &lt;div class=&quot;form-group&quot;&gt; ...

Почему кнопка не работает в Хроме и Опере?
Здравствуйте. Не пойму в чем дело... на сайте стоит кнопка, для перехода на внешнюю страницу. НО проблема в том, что она нормально...

3
 Аватар для sash
89 / 87 / 49
Регистрация: 09.10.2014
Сообщений: 571
28.07.2017, 01:42
Если нормально делать, то никаких онкликов в хтмл не должно быть.. весь js код должен быть отдельно и событие добавляться через
JavaScript
1
2
3
elem.addEventListener('click', function(){
  
});
0
Эксперт JS
2463 / 1769 / 625
Регистрация: 11.07.2016
Сообщений: 4,067
28.07.2017, 09:35
sash, ну зачем же так категорично? Указывать функцию-обработчик события в качестве атрибута тега вполне допустимо.
Inferial, прошёлся по коду по диагонали.
Во-первых, вы забыли заключить значение атрибута onClick тега input#timerhunting в кавычки.
Во-вторых, функция startTimerhunting() не определена. Либо вы перепутали название, либо просто не опубликовали её.
В-третьих, ваши функции описаны внутри анонимной функции. Они не будут доступны в глобальной области видимости. Учтите это.
В-четвёртых,
Цитата Сообщение от Inferial Посмотреть сообщение
при нажатии на кнопку срабатывает скрипт js, и включается таймер, но так же должен состоятся переход на другую страницу save.php
JS работает в рамках одной страницы. Как только будет осуществлён переход на другую страницу - таймер будет удалён. Таким образом данное действие как минимум бессмысленно.
0
0 / 0 / 0
Регистрация: 12.12.2016
Сообщений: 9
28.07.2017, 21:25  [ТС]
Цитата Сообщение от Balanaar Посмотреть сообщение
Во-первых, вы забыли заключить значение атрибута onClick тега input#timerhunting в кавычки.
согласен, не досмотрел.
Цитата Сообщение от Balanaar Посмотреть сообщение
Во-вторых, функция startTimerhunting() не определена. Либо вы перепутали название, либо просто не опубликовали её.
Да, выложил не тот скрипт, точный скрипт ниже:
JavaScript
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
(function() {
    function getElem_Time(outElem) {
        var arr = outElem.innerHTML.split(':')
        return 1000*(3600*(+arr[0])+60*(+arr[1])+(+arr[2]));
    }
    function two_dig (t) {
        return  (parseInt(t)/100).toFixed(2).toString().split('.')[1];
    }
    function getHH_MM_SS(sek) {
        return two_dig (sek/3600)+  ':' + two_dig ((sek/60)%60)+ ':' + two_dig (sek%60);
    }
    var timerId;        // ID setInterval
    var firstSaveVal;   // Тут сохраняем начальное значение Time из элемента;
    var  endDate     =  localStorage.endDate;
    startTimerhunting = function(sel,test){  //test == 1 при запуске по кнопке и == 0 при автозапуске на новой странице, 3 - сброс;
        var outElem = document.getElementById(sel); //объект вывода/ввода цифр
        clearInterval(timerId);
        if(!firstSaveVal)firstSaveVal = outElem.innerHTML;
        if(!endDate &&!test) return false; //Aвтозапуск на новой странице;
        var deltaT = getElem_Time(outElem);
        if(test){
            document.getElementById("timerhunting").disabled = true; //запрет на кнопку
            document.getElementById("timerberries").disabled = true;
            outElem.innerHTML = firstSaveVal;
            deltaT = getElem_Time(outElem);
            delete localStorage.endDate;
            endDate = localStorage.endDate;
        }
        var thisTime = +new Date();
        if(!endDate){
            var timeEnd = thisTime + deltaT;
            localStorage.endDate = sel+','+ timeEnd;
        }
        if(endDate &&!test){
            var arr = endDate.split(',');
            var outElem = document.getElementById(arr[0]);
            var timeEnd = +arr[1];
            document.getElementById("timerhunting").disabled = true; //запрет на кнопку
            document.getElementById("timerberries").disabled = true;
        }
        function setOutTime(){
            if(+new Date()>=timeEnd){
                clearInterval(timerId);
                outElem.innerHTML='00:00:00';
                var money; //объявили переменную
                money = '1'; //присвоили значение преременной
                document.getElementById("timerhunting").disabled = false; //разрешение на кнопку
                document.getElementById("timerberries").disabled = false;
                delete localStorage.endDate;
                return;
            }
            var timeToFinish = parseInt((timeEnd - +new Date())/1000);
            outElem.innerHTML = getHH_MM_SS(timeToFinish);
        }  
        setOutTime();
        timerId = setInterval(setOutTime,1000);
    }
    startTimerhunting("my_timerhunting",0); //Aвтозапуск на новой странице с проверкой сохранненого в Storage(если нет - return);
    window.onfocus =   function (){startTimerhunting("my_timerhunting",0); } //При возврате на вкладку, бывшую неактивной
}());
Цитата Сообщение от Balanaar Посмотреть сообщение
JS работает в рамках одной страницы. Как только будет осуществлён переход на другую страницу - таймер будет удалён. Таким образом данное действие как минимум бессмысленно.
Данное высказывание мне понятно, и полностью с ним согласен. Но, что делает сам скрипт: при нажатии на кнопку начинается отсчет таймера, сама кнопка блокируется, и не зависимо от перезагрузки или закрытия страницы таймер будет работать.
Суть в проблемы в чем: при нажатии на кнопку со значением "1", это самое значение должно передаваться в save.php, а далее обрабатываться и улетать в базу. Данный результат я получаю только в мозиле и EI. Но в хроме и опере не пашет. В этом и суть вопроса.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
28.07.2017, 21:25
Помогаю со студенческими работами здесь

Эффект параллакса не работает в хроме и опере
Собственно, проблема в шапке описана. Сайт - http://flynaut.com/grid/. Что еще примечательно - сначала его делал у себя...

&nbsp; не работает в хроме и опере
&amp;nbsp; не работает в хроме и опере , делал в мозиле пока не отркыл в хроме и опере и не ахнул =-O какие альтернативы можно...

В хроме и опере не работает скрипт со спойлером
Почему у меня в хроме и опере не работает этот скрипт? (подсовываю через 1С:Битрикс) &lt;div class=&quot;divspoiler&quot;&gt;...

Не работает вертикальный скроллинг лендинга в Хроме, Яше, Опере
Забился с решением. Не работает вертикальный скроллинг лендинга в Хроме, Яше, Опере. Только в Мозиле. Сайт-лендинг предполагает плавную...

Не работает событие onclick в хроме
В хроме не срабатывает событие onclick: &lt;option title=images/png.png&quot; class=&quot;optionAddTC&quot; id=&quot;1&quot;...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru