Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.82/137: Рейтинг темы: голосов - 137, средняя оценка - 4.82
28 / 28 / 4
Регистрация: 18.05.2010
Сообщений: 266

Как сделать плавное открытие/закрытие блока на jquery?

20.01.2011, 14:37. Показов 27039. Ответов 21
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
есть например ссылки, при нажатии на одну нужно чтобы на странице плавно появился див-блок, его расположение чтобы можно было настроить, если нажимаю на другую ссылку, блок плавно затухает и на его место плавно появляется другой, ссылок и блоков может быть много. при загрузке самой страницы должен быть на своем месте блок, привязан к ссылке например home.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.01.2011, 14:37
Ответы с готовыми решениями:

Плавное открытие и закрытие
Помогите сделать вот из этого: function show_d() { obj = document.getElementById("test"); obj.style.visibility =...

Как сделать плавное открытие программы?
Здравствуйте! Помогите, пожалуйста, как можно сделать плавную анимацию открытия формы? Стоит VS 2017. Заранее спасибо.

Плавное появление блока при наведении jQuery
Люди добрые, выручайте! Есть блок, по умолчанию он display: none, как сделать чтобы при наведении (именно наведении, hover) он плавно...

21
 Аватар для Sulik78
450 / 203 / 27
Регистрация: 23.12.2010
Сообщений: 645
20.01.2011, 17:07
ну показать спрятать можно несколькими способами
самый простой
JavaScript
1
2
3
4
5
6
$('#show_link').click(function(){
    $('#block').show("normal");
})
$('#hide_link').click(function(){
    $('#block').hide("normal");
})
normal - это скорость показа/скрытия еще может быть fast slow
show_link - id ссылки котороя показывает
hide_link - id ссылки котороя скрывает
block - id блока
0
28 / 28 / 4
Регистрация: 18.05.2010
Сообщений: 266
20.01.2011, 17:23  [ТС]
может я чо не понимаю, но вот например:
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
<script src="http://code.jquery.com/jquery-latest.js"></script>
<script type="text/javascript">
$('#show_link').click(function(){
    $('#block').show("normal");
})
$('#hide_link').click(function(){
    $('#block').hide("normal");
})
</script>
<a href="#" id="hide_link">Click</a>
<div id="block">
ghjhjhjh
</div>
здесь блок видимый, это во-первых
во-вторых прочитайте пожалуйста внимательно, что именно мне нужно
0
 Аватар для Vovan-VE
13210 / 6599 / 1041
Регистрация: 10.01.2008
Сообщений: 15,069
20.01.2011, 17:27
Цитата Сообщение от 4umYOUser Посмотреть сообщение
HTML5
1
2
<script type="text/javascript">
$('#show_link').click(function(){
Разве так можно без $(function(){ ?
HTML5
1
2
3
<script type="text/javascript">
$(function(){
    $('#show_link').click(function(){
0
 Аватар для suharik
261 / 247 / 57
Регистрация: 03.09.2010
Сообщений: 805
20.01.2011, 17:56
Вообще плано открывает и закрывает

JavaScript
1
2
$('#block').fadeIn(200);
$('#block').fadeOut(200);
0
28 / 28 / 4
Регистрация: 18.05.2010
Сообщений: 266
20.01.2011, 18:03  [ТС]
распишу подробнее
только страница index.html:
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<a href="#" id="home">Home</a>
<a href="#" id="about">About</a>
<a href="#" id="contact">Contact</a>
 
<div class="block">
</div>
 
<div id="home">
Home text
</div>
 
<div id="about">
About text
</div>
 
<div id="contact">
Contact text
</div>
когда страница открывается в див class="block" по умолчанию должен подгружатся див id="home"
когда посетитель кликает например по ссылке About, блок id="home" должен плавно потухнуть и на его место должен появится див id="about"
аналогично если кликнуть по ссылке Contact
0
 Аватар для suharik
261 / 247 / 57
Регистрация: 03.09.2010
Сообщений: 805
20.01.2011, 18:29
Не понимаю зачем подгружать дивы в другой див, если можно просто существующие дивы открывать и закрывать.
например.

HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<a href="#" onClick="openDiv('home')">Home</a>
<a href="#"  onClick="openDiv('about')">About</a>
<a href="#"  onClick="openDiv('contact')">Contact</a>
 
<div id="home" class = "openDiv" >
Home text
</div>
 
<div id="about" class = "openDiv">
About text
</div>
 
<div id="contact" class = "openDiv">
Contact text
</div>
CSS
1
2
3
4
.openDiv{
display:none;
//ну и настраиваете блок как хотите
}
JavaScript
1
2
3
4
5
6
7
$(document).ready(function(){ 
 $('#home').css({display:block});
function openDiv (id) {
$(".openDiv").css({display:none});
  $('#'+id+'').fadeIn(200);
};
}
Код не тестил. но работать должно))
0
28 / 28 / 4
Регистрация: 18.05.2010
Сообщений: 266
20.01.2011, 21:08  [ТС]
Цитата Сообщение от suharik Посмотреть сообщение
Код не тестил. но работать должно))
к сожалению, не работает, даже хоум по умолчанию не показывает...
0
 Аватар для suharik
261 / 247 / 57
Регистрация: 03.09.2010
Сообщений: 805
21.01.2011, 11:30
Ваш фаил в студию. Вы jQuery подключили?

Добавлено через 1 час 31 минуту
Так попробуйте
JavaScript
1
2
3
4
5
6
7
function openDiv (id) {
$(".openDiv").css({display:none});
  $('#'+id+'').fadeIn(200);
};
$(document).ready(function(){ 
 $('#home').css({display:block});
});
0
28 / 28 / 4
Регистрация: 18.05.2010
Сообщений: 266
21.01.2011, 12:34  [ТС]
мой код:
HTML5
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
<script type="text/javascript" src="http://code.jquery.com/jquery-latest.js"></script>
 
<script type="text/javascript">
$(document).ready(function(){ 
 $('#home').css({display:block});
function openDiv (id) {
$(".openDiv").css({display:none});
  $('#'+id+'').fadeIn(200);
};
}
</script>
 
<style>
.openDiv{
display:none;
width:300px;
height:200px;
background:#CCC;
//ну и настраиваете блок как хотите
}
</style>
 
<a href="#" onClick="openDiv('home')">Home</a>
<a href="#" onClick="openDiv('about')">About</a>
<a href="#" onClick="openDiv('contact')">Contact</a>
 
<div id="home" class="openDiv" >
Home text
</div>
 
<div id="about" class="openDiv">
About text
</div>
 
<div id="contact" class="openDiv">
Contact text
</div>
добавил только размеры и бекграунд для openDiv
0
 Аватар для suharik
261 / 247 / 57
Регистрация: 03.09.2010
Сообщений: 805
21.01.2011, 12:38
PHP
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
<script type="text/javascript" src="http://code.jquery.com/jquery-latest.js"></script>
 
<script type="text/javascript">
function openDiv (id) {
$(".openDiv").css({display:none});
  $('#'+id+'').fadeIn(200);
};
$(document).ready(function(){ 
 $('#home').css({display:block});
});
 
</script>
 
<style>
.openDiv{
display:none;
width:300px;
height:200px;
background:#CCC;
//ну и настраиваете блок как хотите
}
</style>
 
<a href="#" onClick="openDiv('home')">Home</a>
<a href="#" onClick="openDiv('about')">About</a>
<a href="#" onClick="openDiv('contact')">Contact</a>
 
<div id="home" class="openDiv" >
Home text
</div>
 
<div id="about" class="openDiv">
About text
</div>
 
<div id="contact" class="openDiv">
Contact text
</div>
так сделайте должно заработать
0
28 / 28 / 4
Регистрация: 18.05.2010
Сообщений: 266
21.01.2011, 12:46  [ТС]
Цитата Сообщение от suharik Посмотреть сообщение
так сделайте должно заработать
все равно не работает...
проверь у себя пожалуйста
0
 Аватар для suharik
261 / 247 / 57
Регистрация: 03.09.2010
Сообщений: 805
21.01.2011, 14:01
PHP
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
<html>
<head>
<script type="text/javascript" src="http://code.jquery.com/jquery-latest.js"></script>
<script type="text/javascript">
function openDiv (id) {
$(".openDiv").css({display:'none'});
  $('#'+id+'').fadeIn(200);
};
$(document).ready(function(){ 
 $('#home').css({display:"block"});
});
 
</script>
 <style>
.openDiv{
display:none;
width:300px;
height:200px;
background:#CCC;
//ну и настраиваете блок как хотите
}
</style>
</head>
<body>
 
<a href="javascript:void(0)" onClick="openDiv('home')">Home</a>
<a href="javascript:void(0)" onClick="openDiv('about')">About</a>
<a href="javascript:void(0)" onClick="openDiv('contact')">Contact</a>
 
<div id="home" class="openDiv" >
Home text
</div>
 
<div id="about" class="openDiv">
About text
</div>
 
<div id="contact" class="openDiv">
Contact text
</div>
</body>
</html>
Вот рабочий протестиный код
1
28 / 28 / 4
Регистрация: 18.05.2010
Сообщений: 266
21.01.2011, 14:30  [ТС]
suharik, спасибо, все супер!
но еще маленькая просьба: допиши пожалуйста в скрипт также fadeOut(200), чтобы я мог себе регулировать, сам я не знаю куда дописать
0
 Аватар для suharik
261 / 247 / 57
Регистрация: 03.09.2010
Сообщений: 805
21.01.2011, 14:34
вместо строки
JavaScript
1
$(".openDiv").css({display:'none'});
сделайте
JavaScript
1
$(".openDiv").fadeOut(200);
0
28 / 28 / 4
Регистрация: 18.05.2010
Сообщений: 266
21.01.2011, 14:38  [ТС]
теперь когда переключаю, то новый блок сначало снизу появляется, а потом стает на место старого
0
 Аватар для suharik
261 / 247 / 57
Регистрация: 03.09.2010
Сообщений: 805
21.01.2011, 14:51
ну оставь так
JavaScript
1
2
3
4
5
6
7
8
9
10
11
<script type="text/javascript">
function openDiv (id) {
$(".openDiv").css({display:'none'});
$('#'+id+'').fadeIn(800);
 
};
$(document).ready(function(){ 
 $('#home').css({display:"block"});
});
 
</script>
1
0 / 0 / 0
Регистрация: 09.06.2013
Сообщений: 37
15.09.2013, 15:39
Подскажите а как сделать тоже самое но чтобы не затухание было, а предыдущий блок уезжал влево, на его место новый справа.
0
 Аватар для suharik
261 / 247 / 57
Регистрация: 03.09.2010
Сообщений: 805
15.09.2013, 22:58
Цитата Сообщение от Xion Посмотреть сообщение
Подскажите а как сделать тоже самое но чтобы не затухание было, а предыдущий блок уезжал влево, на его место новый справа.
Можно подключить обычный слайдер.
А если с нуля, то лучше использовать списки <li> и делать через animate например. Анимируешь позиционирование списка а остальное через css
0
0 / 0 / 0
Регистрация: 09.06.2013
Сообщений: 37
16.09.2013, 07:33
А просто другую анимацию вместо проявления нельзя вставить?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.09.2013, 07:33
Помогаю со студенческими работами здесь

Открытие и закрытие блока
Люди добрые, подскажите, у меня имеются такие данные: между &lt;head&gt; и &lt;head&gt; &lt;style type=&quot;text/css&quot;&gt;.UhideBlock...

Как сделать открытие (закрытие) дверей с ключами?
Всем добрый вечер! Помогите, пожалуйста, начинающему разработчику 3d игр на unity. Делаю игру в которой есть несколько дверей и к...

Как сделать Закрытие/Открытие элемента, с крестиком?
https://codepen.io/bogdanmaslyanik/pen/MPydzm &lt;div class=&quot;alblackover&quot;&gt; &lt;h6 id=&quot;form_show&quot; style=&quot;padding: 12px 0&quot;&gt;Форма...

Как сделать закрытие div блока через 10 сек
Здравствуйте! У меня есть сайт http://anketnik.lakreon.ru/ на нем в в шапке сайта есть выпадающий список с номерами телефонов, мне нужно...

Открытие и скрытие блока на JQuery
Всем привет! Помогите. У меня есть блок, который скрыт в свойствах CSS и нужно, что бы он поменял значение на Flex и отобразился...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru