Я хотел бы добавить всплывающее сообщение, подобное тому, которое появляется в Stack Overflow, когда я не вошел в систему и пытаюсь использовать кнопки голосования.
Как лучше всего этого добиться? Это сделано с помощью библиотеки jquery?
Я хотел бы добавить всплывающее сообщение, подобное тому, которое появляется в Stack Overflow, когда я не вошел в систему и пытаюсь использовать кнопки голосования.
Как лучше всего этого добиться? Это сделано с помощью библиотеки jquery?
Ответы:
РЕДАКТИРОВАТЬ : В приведенном ниже коде показано, как воспроизвести полосы, которые отображаются в верхней части экрана, когда вы получаете новый значок, впервые заходите на сайт и т. Д. Для диалоговых окон, которые вы получаете, когда вы пытаетесь комментировать слишком быстро, проголосуйте для вашего собственного вопроса и т. д. ознакомьтесь с этим вопросом, где я покажу, как это сделать, или просто перейдите к примеру .
Вот как это делает Stackoverflow:
Это разметка, изначально скрытая, чтобы мы могли ее добавить:
<div id='message' style="display: none;">
<span>Hey, This is my Message.</span>
<a href="#" class="close-notify">X</a>
</div>
Вот применяемые стили:
#message {
font-family:Arial,Helvetica,sans-serif;
position:fixed;
top:0px;
left:0px;
width:100%;
z-index:105;
text-align:center;
font-weight:bold;
font-size:100%;
color:white;
padding:10px 0px 10px 0px;
background-color:#8E1609;
}
#message span {
text-align: center;
width: 95%;
float:left;
}
.close-notify {
white-space: nowrap;
float:right;
margin-right:10px;
color:#fff;
text-decoration:none;
border:2px #fff solid;
padding-left:3px;
padding-right:3px
}
.close-notify a {
color: #fff;
}
А это javascript (с использованием jQuery):
$(document).ready(function() {
$("#message").fadeIn("slow");
$("#message a.close-notify").click(function() {
$("#message").fadeOut("slow");
return false;
});
});
И вуаля. В зависимости от настроек вашей страницы вы также можете изменить отображаемую верхнюю границу основного поля.
Также проверьте диалог пользовательского интерфейса jQuery
Использование ModalPopup в наборе инструментов управления AJAX - еще один способ получить этот эффект.
Вот что я обнаружил, просмотрев исходный код StackOverflow. Надеюсь сэкономит время для кого-то. Функция showNotification используется для всех этих всплывающих сообщений.
var showNotification=function(jClicked,msg){master.showErrorPopup(jClicked.parent(),msg)};
var showFadingNotification=function(jClicked,msg){master.showErrorPopup(jClicked.parent(),msg,true)};
//master...
showErrorPopup: function (e, h, f) {
var g = $('<div class="error-notification supernovabg"><h2>' + h + "</h2>" + (f ? "" : "(click on this box to dismiss)") + "</div>");
var i = function () {
g.fadeOutAndRemove()
};
$(e).append(g);
g.click(i).fadeIn("fast");
setTimeout(i, (f ? Math.max(2500, h.length * 40) : 1000 * 30))
}
css
.error-notification{z-index:1;cursor:pointer;display:none;position:absolute;padding:15px;-moz-box-shadow:2px 2px 5px #000;-webkit-box-shadow:2px 2px 5px #000;box-shadow:2px 2px 5px #000;}
.error-notification a{color:inherit;text-decoration:underline;}
.error-notification li{font-size:110%;padding-top:3px;}
.supernovabg{color:#fff !important;background-color:#fe7a15 !important;}
Круто, как они используют длину сообщения для установки таймаута затухания. Я не осознавал, что все сообщения (стиль без затухания) на самом деле исчезают через 30 секунд.