Изменение атрибута Action у HTML формы (jQuery)
ногда возникает необходимость менять значение атрибута HTML формы action без перезагрузски страницы, приямо на лету, в зависимости от каких либо значений или действий пользователя на странице. Примером может служить поисковая форма на сайте, которая в зависимости от выбора типа поиска с помощью выпадающего «селекта», посылает запросы на разные URL. Часто на сайте используется поиск от Google и внутренний поиск.
Для реализации данной возможности, достаточно написать не больший JS скрипт, который будет обрабатывать данные на странице и в зависимости от них, подставлять нужное значение в атрибут action HTML формы. Приведу два примера, один из которых использует jQuery.
Пример 1, листинг JavaScript и HTML.
<html>
<head>
<script language="javascript">
function setNewAction(radioGroupObj)
{
for(var i = 0 ; i < radioGroupObj.length ; i++)
{
if(radioGroupObj[i].checked)
{
document.forms[0].action =
radioGroupObj[i].value;
}
}
document.forms[0].submit();
}
</script>
</head>
</body>
<form name="form1" id="my_form" method="get" action="test.html">
<p>
<label>
<input type="radio" name="group1" value="page1.php">
Form Action Page 1</label>
<br>
<label>
<input type="radio" name="group1" value="page2.aspx">
Form Action Page 2</label>
<br>
</p>
<input type="button" id="butt" value="CLICK ME"
onClick="setNewAction(this.form.group1)">
</form>
</body>
</html> |
Пример 2. С использованием jQuery.
<html>
<head>
<script src="jquery.js"></script>
<script language="javascript">
$(document).ready
(
function()
{
$("input[@name='group1']").click
(
function()
{
$("#my_form").attr("action",$(this).val());
}
);
}
);
</script>
</head>
</body>
<form name="form1" id="my_form" method="get" action="test.html">
<p>
<label>
<input type="radio" name="group1" value="page1.php">
Form Action Page 1</label>
<br>
<label>
<input type="radio" name="group1" value="page2.aspx">
Form Action Page 2</label>
<br>
</p>
<input type="submit" value="Submit">
</form>
</body>
</html> |
Пример 3. С jQuery и комментариями, как работает скрипт
<html>
<head>
<script src="jquery.js"></script>
<script language="javascript">
$(document).ready(function(){
$("#type").change(function(e){ // при выборе значение в поле селект, выполняем код функции
var id = $("#type option:selected").val(); // получаем значение из поля селект
if(id==1){ // если значение равно 1, задаем атрибуту action формы #formsearchtop, значение /search/
$("#formsearchtop").attr("action","/search/");
}
if(id==2)
{ // если значение равно 2, задаем атрибуту action формы #formsearchtop, значение https://www.google.ru/search
$("#formsearchtop").attr("action","https://www.google.ru/search");
}
});
</script>
</head>
<body>
<form method="get" action="/search/" id="formsearchtop">
<input type="text" name="q" rel="Поиск по сайту" value="" class="placeholder search-input"/>
<input type="submit" value="найти" class="search-submit"/>
<select name="type" id="type">
<option value="1">поиск по сайту</option>
<option value="1">поиск в гугле</option>
</select>
</form>
</body>
</html> |
Все предельно просто. Делайте свои страницы более живыми, дружественными и удобными для конечного пользователя. Подобные динамические решения экономят время и трафик посетителя делая ваш сайт заметно привлекательнее. Впрочем вы и сами прекрасно это понимаете).
Похожие записи
Оставить комментарий
Full Stack
Senior, Architect
предложить оффер
- jQuery: как получить значение атрибута?
- PHP работа с изображением, класс SimpleImage
- Комментарии на PHP, Ajax, mySQL
- Интеграция с API ОСАГО сайта sravni.ru
- PHP: Категории бесконечного уровня вложенности.
- Nginx редирект на другой сервис с сохранением URL спросил (а) Сергей
- Исполнитель пропал, почему такое случается и понять с кем работать? спросил (а) Артем
- Можно ли WordPress считать универсальным движком? спросил (а) Андрей
- Что такое самописный скрипт или CMS? спросил (а) Антон
- Как при поиске в linux используя grep, добавить исключения? спросил (а) Алексей
- к записи Обзор Insurance CMS — платформы для сайтов по страхованию
- к записи Консольный скрипт(JavaScript) для автоматических заказов на OZON
- к записи Консольный скрипт(JavaScript) для автоматических заказов на OZON
- к записи Как создать Telegram-бота с авторизацией через сайт
- к записи PHP скрипт: каталог закладок на сайты
- к записи Валидация на PHP
- к записи Сколько зарабатывают в бизнесе на совместных покупках
Archive
- +2025 (28)
- Июль 2025 (1)
- Май 2025 (1)
- Апрель 2025 (7)
- Март 2025 (4)
- Февраль 2025 (9)
- Январь 2025 (6)
- +2024 (35)
- Декабрь 2024 (7)
- Ноябрь 2024 (13)
- Октябрь 2024 (8)
- Сентябрь 2024 (1)
- Август 2024 (5)
- Май 2024 (1)
- +2023 (27)
- Ноябрь 2023 (1)
- Октябрь 2023 (13)
- Сентябрь 2023 (10)
- Апрель 2023 (1)
- Март 2023 (1)
- Февраль 2023 (1)
- +2022 (21)
- Декабрь 2022 (11)
- Ноябрь 2022 (1)
- Май 2022 (2)
- Апрель 2022 (2)
- Март 2022 (3)
- Февраль 2022 (1)
- Январь 2022 (1)
- +2021 (17)
- Декабрь 2021 (5)
- Ноябрь 2021 (2)
- Июль 2021 (1)
- Июнь 2021 (2)
- Май 2021 (5)
- Апрель 2021 (1)
- Март 2021 (1)
- +2020 (20)
- Декабрь 2020 (6)
- Сентябрь 2020 (2)
- Август 2020 (1)
- Июль 2020 (2)
- Май 2020 (2)
- Апрель 2020 (2)
- Март 2020 (2)
- Февраль 2020 (1)
- Январь 2020 (2)
- +2019 (18)
- Декабрь 2019 (3)
- Ноябрь 2019 (2)
- Октябрь 2019 (2)
- Сентябрь 2019 (1)
- Август 2019 (2)
- Июль 2019 (1)
- Июнь 2019 (1)
- Апрель 2019 (2)
- Март 2019 (1)
- Февраль 2019 (3)
- +2018 (44)
- Декабрь 2018 (4)
- Ноябрь 2018 (7)
- Октябрь 2018 (8)
- Сентябрь 2018 (1)
- Август 2018 (4)
- Июль 2018 (5)
- Май 2018 (3)
- Апрель 2018 (7)
- Март 2018 (1)
- Февраль 2018 (2)
- Январь 2018 (2)
- +2017 (19)
- Декабрь 2017 (2)
- Ноябрь 2017 (1)
- Октябрь 2017 (1)
- Сентябрь 2017 (2)
- Июль 2017 (1)
- Июнь 2017 (1)
- Май 2017 (2)
- Апрель 2017 (3)
- Март 2017 (2)
- Февраль 2017 (1)
- Январь 2017 (3)
- +2016 (36)
- Декабрь 2016 (3)
- Ноябрь 2016 (3)
- Октябрь 2016 (2)
- Сентябрь 2016 (3)
- Август 2016 (7)
- Июнь 2016 (3)
- Май 2016 (3)
- Апрель 2016 (3)
- Февраль 2016 (1)
- Январь 2016 (8)
- +2015 (36)
- Ноябрь 2015 (5)
- Октябрь 2015 (4)
- Сентябрь 2015 (1)
- Август 2015 (8)
- Июнь 2015 (1)
- Май 2015 (4)
- Апрель 2015 (8)
- Март 2015 (3)
- Февраль 2015 (2)
- +2014 (26)
- Ноябрь 2014 (2)
- Октябрь 2014 (5)
- Сентябрь 2014 (6)
- Июль 2014 (1)
- Июнь 2014 (2)
- Май 2014 (3)
- Апрель 2014 (6)
- Февраль 2014 (1)
- +2013 (27)
- Декабрь 2013 (2)
- Ноябрь 2013 (1)
- Октябрь 2013 (1)
- Август 2013 (1)
- Июль 2013 (3)
- Июнь 2013 (10)
- Май 2013 (1)
- Апрель 2013 (2)
- Февраль 2013 (3)
- Январь 2013 (3)
- +2012 (41)
- Декабрь 2012 (2)
- Ноябрь 2012 (3)
- Октябрь 2012 (7)
- Сентябрь 2012 (2)
- Август 2012 (1)
- Июль 2012 (3)
- Июнь 2012 (2)
- Май 2012 (6)
- Апрель 2012 (2)
- Март 2012 (7)
- Февраль 2012 (5)
- Январь 2012 (1)
- +2011 (57)
- Декабрь 2011 (6)
- Ноябрь 2011 (2)
- Октябрь 2011 (3)
- Сентябрь 2011 (5)
- Август 2011 (4)
- Июль 2011 (3)
- Июнь 2011 (3)
- Май 2011 (3)
- Апрель 2011 (4)
- Март 2011 (10)
- Февраль 2011 (5)
- Январь 2011 (9)
- +2010 (43)
- Декабрь 2010 (7)
- Ноябрь 2010 (21)
- Октябрь 2010 (14)
- Сентябрь 2010 (1)
Свежие записи
- Список всех BIN российский банков в JSON 10.07.2025
- Плагин для WordPress, поддержка заголовка If-Modified-Since 22.05.2025
- Настройка NAT на OPNsense 30.04.2025
- Модуль для DLE парсинга RSS ленты с изображениями 14.04.2025
- Проверка CORS онлайн 04.04.2025