Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: jQuery

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (2): [1] 2 »   

> Описание: Radio and input
JoyStick
Отправлено: 12 Июля, 2012 - 15:52:20
Post Id


Новичок


Покинул форум
Сообщений всего: 29
Дата рег-ции: Янв. 2012  


Помог: 0 раз(а)




<script type="text/javascript">
$(function(){
$('#activ, #dis').click(function (){
if ($('#dis').is(':checked')) {
$('#elementsToOperateOn input').attr('disabled', true);
}
if ($('#active').is(':checked')){
$('#elementsToOperateOn input').attr('enabled');
}
})
})
</script>

<form method="post" action="">
<input id="active" type="radio" name="toggle" />
<input id="dis" type="radio" name="toggle" />
<div id="elementsToOperateOn">
<input type="text" name="name" />
</div>
</form>

При выборе одного radiobutton input становиться не активным, а вот при выборе другого radiobutton нужно что бы оно становилось активным, но не хочет. Помогите кто чем может)
 
 Top
Alho
Отправлено: 12 Июля, 2012 - 16:14:47
Post Id



Посетитель


Покинул форум
Сообщений всего: 322
Дата рег-ции: Апр. 2012  


Помог: 11 раз(а)




К примеру так:
CODE (javascript):
скопировать код в буфер обмена
  1. <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
  2. <script type="text/javascript">
  3.         $(function(){
  4.                 $('#active').click(function (){
  5.                 $('#elementsToOperateOn input').removeAttr('disabled');
  6.                 });
  7.                 $('#dis').click(function (){
  8.                 $('#elementsToOperateOn input').attr('disabled', 'disabled');
  9.                 });
  10.  
  11.         })
  12. </script>
  13.  
  14. <form method="post" action="">
  15.                 <input id="active" type="radio" name="toggle" />
  16.                 <input id="dis" type="radio" name="toggle" />
  17.         <div id="elementsToOperateOn">
  18.                 <input type="text" name="name" />
  19.         </div>
  20. </form>


P.S. Оформляйте код в соответствующие теги.
 
 Top
JoyStick
Отправлено: 12 Июля, 2012 - 16:16:24
Post Id


Новичок


Покинул форум
Сообщений всего: 29
Дата рег-ции: Янв. 2012  


Помог: 0 раз(а)




Благодарю)
 
 Top
armancho7777777 Супермодератор
Отправлено: 12 Июля, 2012 - 16:42:47
Post Id



Активный участник


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


Помог: 221 раз(а)




Alho, в jQuery 1.7 манипуляции с атрибутом disabled:

CODE (javascript):
скопировать код в буфер обмена
  1. if($('input:ceckbox').is(':disabled') == true)
  2. {
  3.     $('input:ceckbox').attr('disabled', false);
  4. }
  5. else
  6. {
  7.     $('input:ceckbox').attr('disabled', true);
  8. }

(Отредактировано автором: 12 Июля, 2012 - 16:43:44)

 
 Top
Viper
Отправлено: 13 Июля, 2012 - 09:03:10
Post Id



Активный участник


Покинул форум
Сообщений всего: 4555
Дата рег-ции: Февр. 2007  
Откуда: Симферополь


Помог: 98 раз(а)




armancho7777777 можно проще Улыбка

CODE (javascript):
скопировать код в буфер обмена
  1. $('input:ceckbox').attr('disabled', $(this).is(':disabled'));


-----
Список фильмов с описанием, блекджеком и... для Joomla? -> https://киноархив[dot]com
Демо нового движка для сайта php.su -> php[dot]su, проект на гитхабе
 
 Top
armancho7777777 Супермодератор
Отправлено: 13 Июля, 2012 - 09:38:52
Post Id



Активный участник


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


Помог: 221 раз(а)




Что это?
Viper пишет:
CODE (javascript):
скопировать код в буфер обмена
  1. $('input:ceckbox').attr('disabled', $(this).is(':disabled'));
 
 Top
Viper
Отправлено: 13 Июля, 2012 - 09:51:35
Post Id



Активный участник


Покинул форум
Сообщений всего: 4555
Дата рег-ции: Февр. 2007  
Откуда: Симферополь


Помог: 98 раз(а)




armancho7777777 пишет:
Что это?
что именно?
is() возвращает true/false. Нет необходимости писать полную конструкцию if


-----
Список фильмов с описанием, блекджеком и... для Joomla? -> https://киноархив[dot]com
Демо нового движка для сайта php.su -> php[dot]su, проект на гитхабе
 
 Top
armancho7777777 Супермодератор
Отправлено: 13 Июля, 2012 - 10:03:56
Post Id



Активный участник


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


Помог: 221 раз(а)




Так оно будет постоянно так одно значение возвращать.
 
 Top
Viper
Отправлено: 13 Июля, 2012 - 11:09:59
Post Id



Активный участник


Покинул форум
Сообщений всего: 4555
Дата рег-ции: Февр. 2007  
Откуда: Симферополь


Помог: 98 раз(а)




armancho7777777 в вашем случае это тоже самое.


-----
Список фильмов с описанием, блекджеком и... для Joomla? -> https://киноархив[dot]com
Демо нового движка для сайта php.su -> php[dot]su, проект на гитхабе
 
 Top
armancho7777777 Супермодератор
Отправлено: 13 Июля, 2012 - 11:24:46
Post Id



Активный участник


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


Помог: 221 раз(а)




Да нет)
Вы что?
CODE (javascript):
скопировать код в буфер обмена
  1.  
  2. // Если неактивный
  3. if($('input:ceckbox').is(':disabled') == true)
  4. {
  5.     // То делаем активным
  6.     $('input:ceckbox').attr('disabled', false);
  7. }
  8. else
  9. {  
  10.     // ... а иначе делаем неактивным
  11.     $('input:ceckbox').attr('disabled', true);
  12. }
  13.  

Одним словом переключатель.
У Вас же делаем неактивным, если он изначально таким и был,
и наоборот, активным, если изначально он был активен))
В чём логика?)
CODE (javascript):
скопировать код в буфер обмена
  1.  
  2. $('input:ceckbox').attr('disabled', $(this).is(':disabled'));

(Отредактировано автором: 13 Июля, 2012 - 11:36:12)

 
 Top
tuareg
Отправлено: 13 Июля, 2012 - 11:56:46
Post Id


Участник


Покинул форум
Сообщений всего: 1234
Дата рег-ции: Июнь 2010  


Помог: 69 раз(а)




Не мучайтесь все просто.
http://jsfiddle[dot]net/tuareg/zXWhT/
 
 Top
armancho7777777 Супермодератор
Отправлено: 13 Июля, 2012 - 12:04:09
Post Id



Активный участник


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


Помог: 221 раз(а)




Радость Радость
Блин, только дошло))
Извиняюсь))
 
 Top
armancho7777777 Супермодератор
Отправлено: 13 Июля, 2012 - 17:48:55
Post Id



Активный участник


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


Помог: 221 раз(а)




Только правильней всё же тогда так:
CODE (javascript):
скопировать код в буфер обмена
  1. $('input:ceckbox').attr('disabled', !$(this).is(':disabled'));

А не так:
CODE (javascript):
скопировать код в буфер обмена
  1. $('input:ceckbox').attr('disabled', $(this).is(':disabled'));
 
 Top
tuareg
Отправлено: 13 Июля, 2012 - 17:53:33
Post Id


Участник


Покинул форум
Сообщений всего: 1234
Дата рег-ции: Июнь 2010  


Помог: 69 раз(а)




armancho7777777 пишет:
Только правильней всё же тогда так:
CODE (javascript):
скопировать код в буфер обмена
  1. $('input:ceckbox').attr('disabled', !$(this).is(':disabled'));

А не так:
CODE (javascript):
скопировать код в буфер обмена
  1. $('input:ceckbox').attr('disabled', $(this).is(':disabled'));

А почему не prop()? Он же специально для этого сделан? И быстрее должен работать?
 
 Top
armancho7777777 Супермодератор
Отправлено: 13 Июля, 2012 - 17:57:18
Post Id



Активный участник


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


Помог: 221 раз(а)




Я имел в виду синтаксис.
Предложенный код Viperа, как я и писал выше, не верен.

tuareg пишет:
А почему не prop()?

Я просто взял пример что выше.

(Отредактировано автором: 13 Июля, 2012 - 18:22:39)

 
 Top
Страниц (2): [1] 2 »
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Напишите за меня, пожалуйста »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB