请看看整个代码,如果你复制并粘贴到你的HTML然后应该工作。使代码更健壮(jQuery)
正如你可以在下面的代码中看到的,我必须为每个动作(jquery,css)创建两组代码,我试图实现的是,我只需要有一组代码下面的动作...
我不担心点击事件太多,实际上我想有两个单独的点击事件。 $("#button").click(function(){...}
,$("#button1").click(function(){...}
更新时间:
HTML:
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>yensdesign.com - How to create a stuning and smooth popup in jQuery</title>
<link rel="stylesheet" href="general.css" type="text/css" media="screen" />
<script src="http://jqueryjs.googlecode.com/files/jquery-1.2.6.min.js" type="text/javascript"></script>
<script src="popup.js" type="text/javascript"></script>
</head>
<body>
<center>
<div id="button">
<input type="submit" value="button" /></div>
<div id="button1">
<input type="submit" value="button1" /></div>
</center>
<div id="popupContact">
<a id="popupContactClose">x</a>
<h1>
Title of our cool popup, yay!</h1>
<p id="contactArea">
Here we have a simple but interesting sample of our new stuning and smooth popup.
</p>
</div>
<div id="popupContact1">
<a id="popupContactClose1">x</a>
<h1>
one more, yay!</h1>
<p id="contactArea1">
Here we have a simple but interesting sample of our new stuning and smooth popup.
</p>
</div>
<div id="backgroundPopup">
</div>
<div id="backgroundPopup1">
</div>
</body>
</html>
的jQuery:
var popupStatus = 0;
var popupStatus1 = 0;
//loading popup with jQuery magic!
function loadPopup(){
//loads popup only if it is disabled
if(popupStatus==0){
$("#backgroundPopup").css({"opacity": "0.7" });
$("#backgroundPopup").fadeIn("slow");
$("#popupContact").fadeIn("slow");
popupStatus = 1;
}
}
//loading popup with jQuery magic!
function loadPopup1() {
//loads popup only if it is disabled
if (popupStatus == 0) {
$("#backgroundPopup1").css({ "opacity": "0.7" });
$("#backgroundPopup1").fadeIn("slow");
$("#popupContact1").fadeIn("slow");
popupStatus1 = 1;
}
}
//disabling popup with jQuery magic!
function disablePopup(){
//disables popup only if it is enabled
if(popupStatus==1){
$("#backgroundPopup").fadeOut("slow");
$("#popupContact").fadeOut("slow");
popupStatus = 0;
}
}
//disabling popup with jQuery magic!
function disablePopup1(){
//disables popup only if it is enabled
if(popupStatus1==1){
$("#backgroundPopup1").fadeOut("slow");
$("#popupContact1").fadeOut("slow");
popupStatus1 = 0;
}
}
//centering popup
function centerPopup(){
//request data for centering
var windowWidth = document.documentElement.clientWidth;
var windowHeight = document.documentElement.clientHeight;
var popupHeight = $("#popupContact").height();
var popupWidth = $("#popupContact").width();
//centering
$("#popupContact").css({
"position": "absolute",
"top": windowHeight/2-popupHeight/2,
"left": windowWidth/2-popupWidth/2
});
//only need force for IE6
$("#backgroundPopup").css({
"height": windowHeight
});
}
//centering popup
function centerPopup1() {
//request data for centering
var windowWidth = document.documentElement.clientWidth;
var windowHeight = document.documentElement.clientHeight;
var popupHeight = $("#popupContact1").height();
var popupWidth = $("#popupContact1").width();
//centering
$("#popupContact1").css({
"position": "absolute",
"top": windowHeight/2 - popupHeight/2,
"left": windowWidth/2 - popupWidth/2
});
//only need force for IE6
$("#backgroundPopup1").css({
"height": windowHeight
});
}
//CONTROLLING EVENTS IN jQuery
$(document).ready(function()
{
//LOADING POPUP
//Click the button event!
$("#button").click(function(){
//centering with css
centerPopup();
//load popup
loadPopup();
});
$("#button1").click(function() {
//centering with css
centerPopup1();
//load popup
loadPopup1();
});
//CLOSING POPUP
//Click the x event!
$("#popupContactClose").click(function(){
disablePopup();
});
//Click the x event!
$("#popupContactClose1").click(function() {
disablePopup1();
});
//Click out event!
$("#backgroundPopup").click(function(){
disablePopup();
});
$("#backgroundPopup1").click(function() {
disablePopup1();
});
//Press Escape event!
$(document).keypress(function(e){
if(e.keyCode==27 && popupStatus==1){
disablePopup();
}
if(e.keyCode==27 && popupStatus1==1){
disablePopup1();
}
});
});
CSS
#backgroundPopup{
display:none;
position:fixed;
_position:absolute; /* hack for internet explorer 6*/
height:100%;
width:100%;
top:0;
left:0;
background:#000000;
border:1px solid #cecece;
z-index:1;
}
#backgroundPopup1{
display:none;
position:fixed;
_position:absolute; /* hack for internet explorer 6*/
height:100%;
width:100%;
top:0;
left:0;
background:#000000;
border:1px solid #cecece;
z-index:1;
}
#popupContact{
display:none;
position:fixed;
_position:absolute; /* hack for internet explorer 6*/
height:384px;
width:408px;
background:#FFFFFF;
border:2px solid #cecece;
z-index:2;
padding:12px;
font-size:13px;
}
#popupContact1{
display:none;
position:fixed;
_position:absolute; /* hack for internet explorer 6*/
height:384px;
width:408px;
background:#FFFFFF;
border:2px solid #cecece;
z-index:2;
padding:12px;
font-size:13px;
}
#popupContact h1{
text-align:left;
color:#6FA5FD;
font-size:22px;
font-weight:700;
border-bottom:1px dotted #D3D3D3;
padding-bottom:2px;
margin-bottom:20px;
}
#popupContact1 h1{
text-align:left;
color:#6FA5FD;
font-size:22px;
font-weight:700;
border-bottom:1px dotted #D3D3D3;
padding-bottom:2px;
margin-bottom:20px;
}
#popupContactClose{
font-size:14px;
line-height:14px;
right:6px;
top:4px;
position:absolute;
color:#6fa5fd;
font-weight:700;
display:block;
}
#popupContactClose1{
font-size:14px;
line-height:14px;
right:6px;
top:4px;
position:absolute;
color:#6fa5fd;
font-weight:700;
display:block;
}
#button{
text-align:center;
margin:100px;
}
#button1{
text-align:center;
margin:100px;
}
末更新
我下面这个blog一件事就卡住我的是,我有两个链接,我为了创建了两个独立的环节的工作,我有两次添加相同的代码在jQuery和CSS ...但我认为应该有一个更好的方式做...重复的代码只是名称差异。
我已经为了增加代码的核心所以我Button1的工作,我必须添加两次相同的代码,如下图所示,只需命名差异
<div id="button"><input type="submit" value="Press me please!" /></div>
<div id="button1"><input type="submit" value="Press one more time!" /></div>
<div id="popupContact">
<a id="popupContactClose">x</a>
<h1>Title of our cool popup, yay!</h1>
<p id="contactArea">
Here we have a simple but interesting sample
</p>
</div>
了jQuery的源代码:
$("#backgroundPopup1").css({
"opacity": "0.7"
});
$("#backgroundPopup1").fadeIn("slow");
$("#popupContact1").fadeIn("slow");
名为.css
#popupContact {
display:none;
position:fixed;
_position:absolute; /* hack for internet explorer 6*/
height:384px;
width:408px;
background:#FFFFFF;
border:2px solid #cecece;
z-index:2;
padding:12px;
font-size:13px;
}
有东西从你的jQuery失踪......我看不到任何代码的按钮。 – Sparky 2012-04-25 18:55:45
我没有过去的完整代码但你可以看看我的链接 - 博客链接 – 2012-04-25 18:59:37
没有错,但链接你的问题应该是完全独立的。 http://sscce.org – Sparky 2012-04-25 19:06:18