作者:王晓东 | 来源:互联网 | 2023-06-07 19:56
效果图:
//左边图片路径
22 leftAlt:"advertising",//左边广告图片的alt值
23 rightSrc:"dlAdvPic.jpg",//右边图片路径
24 rightAlt:"advertising",//右边广告图片的alt值
25 leftZindex:800,//左边层级
26 rightZindex:800,//右边层级
27 strClose:"关闭",
28 //下面2项不做参数给出
29 leftClass:"dlBoxLeft",//左边class
30 rightClass:"dlBoxRight"//右边class
31 }
32 optiOns= $.extend(defaults,options);
33 var html="";
34 if(options.leftAdvStr===1){
35 html+="
"
;
36 html+="
"
;
37 html+="
"
;
38 html+="
"
;
39 }
40 if(options.rightAdvStr===1
){
41 html+="
"
;
42 html+="
"
;
43 html+="
"
;
44 html+="
"
;
45 }
46 $("body"
).append(html);
47 $(".dlAdvLeftClose,.dlAdvRightClose").on("click",
function(){
48 if($(
this).is(".dlAdvLeftClose"
))
49 $("."+options.leftClass).fadeOut(options.leftCloseTime,
function(){
50 $(
this).remove();
51 });
52 else if($(
this).is(".dlAdvRightClose"
))
53 $("."+options.rightClass).fadeOut(options.rightCloseTime,
function(){
54 $(
this).remove();
55 });
56 })
57 58 59 var leftAdv=$("."+
options.leftClass),
60 rightAdv=$("."+
options.rightClass),
61 dlAdvClose.dlAdvCloseDiv").eq(0
).outerHeight();
62 leftAdv.css({"z-index"
:options.leftZindex});
63 rightAdv.css({"z-index"
:options.rightZindex});
64 function changeImgSize(imgObj,width,height){
65 height-=
dlAdvCloseHeight;
66 imgObj.parent().width(width).height(height);
67 imgObj.css({height:"100%",width:"100%"
});
68 }
69 function getAdvTop(pos,type){
//pos,左,右,type,效果 70 if(type===0
){
71 if(pos==="left"
){
72 return {top:options.leftToTop+"px"
};
73 }
74 else if(pos==="right"
){
75 return {top:options.rightToTop+"px"
};
76 }
77 }
78 else if(type===1
){
79 var scrollTop=
$(window).scrollTop();
80 var top=0
;
81 if(pos==="left"
){
82 top=options.leftToTop+
scrollTop;
83 return {top:top+"px"
};
84 }
85 else if(pos==="right"
){
86 top=options.rightToTop+
scrollTop;
87 return {top:top+"px"
};
88 }
89 90 }
91 else{alert("方法getAdvTop的type有误"
)}
92 }
93 var leftAdvSize={width:options.leftWidth+"px",height:options.leftHeight+"px"
};
94 var rightAdvSize={width:options.rightWidth+"px",height:options.rightHeight+"px"
};
95 var leftAdvPos={left:options.leftToLeft+"px"
};
96 var rightAdvPos={right:options.rightToRight+"px"
};
97 changeImgSize($(".dlAdvleftImg"
),options.leftWidth,options.leftHeight);
98 changeImgSize($(".dlAdvRightImg"
),options.rightWidth,options.rightHeight);
99 function scrollMove(num){
//num是数值,不同的数值表示的不同的缓慢恢复的对象100 $(window).scroll(
function(){
101 var scrollTop=$(window).scrollTop(),top=0
;
102 if(num===-1){
//左边103 top=scrollTop+
options.leftToTop;
104 setTimeout(
function(){
105 leftAdv.css({top:top+"px"
});
106 },options.leftTime);
107 }
108 else if(num===1){
//右边109 top=options.rightToTop+
scrollTop;
110 // rightAdv.animate({top:top+"px"},1000)111 setTimeout(
function(){
112 //rightAdv.animate({top:top+"px"},1000)113 rightAdv.css({top:top+"px"
});
114 },options.rightTime)
115 116 }
117 else if(num===2){
//两边118 var leftTop=scrollTop+
options.leftToTop;
119 var rightTop=scrollTop+
options.rightToTop;
120 setTimeout(
function(){
121 leftAdv.css({top:leftTop+"px"
});
122 },options.leftTime)
123 setTimeout(
function(){
124 rightAdv.css({top:rightTop+"px"
});
125 },options.rightTime);
126 }
127 });
128 }
129 var whoMove=0;
//0,都不缓慢移动,-1,左边缓慢移动,1表示右边缓慢移动,2表示都移动130 if(options.leftType===0){
//稳固不动131 leftAdv.css({"position":"fixed"}).css(getAdvTop("left"
,options.leftType)).css(leftAdvSize).css(leftAdvPos);
132 }
133 else if(options.leftType===1){
//缓慢恢复134 leftAdv.css({"position":"absolute"}).css(getAdvTop("left"
,options.leftType)).css(leftAdvSize).css(leftAdvPos);
135 whoMove=-1
;
136 }
137 else {
138 alert("左对联广告的效果参数传递有误"
);
139 }
140 if(options.rightType===0
){
141 rightAdv.css({"position":"fixed"}).css(getAdvTop("right"
,options.rightType)).css(rightAdvSize).css(rightAdvPos);
142 }
143 else if(options.rightType===1
){
144 rightAdv.css({"position":"absolute"}).css(getAdvTop("right"
,options.rightType)).css(rightAdvSize).css(rightAdvPos);
145 whoMove=(whoMove===0?1:2
);
146 }
147 else {
148 alert("右对联广告的效果参数传递有误"
);
149 }
150 if(whoMove===0){}
//都不缓慢恢复151 else if(whoMove===-1){
//左边缓慢移动152 scrollMove(whoMove);
153 }
154 else if(whoMove===1){
//右边缓慢移动155 scrollMove(whoMove)
156 }
157 else if(whoMove===2){
//左右都缓慢移动158 scrollMove(whoMove)
159 }
160 }
161 });
162 })(jQuery);
163
css代码:
1 .dlBoxLeft{ border:1px solid #ccc;padding:3px;background-color:#efefef; }
2 .dlBoxRight{border:1px solid #ccc;padding:3px; background-color:#efefef;}
3 .dlAdvLeftImgBox{ }
4 .dlAdvCloseDiv{background-image:url(dlCloseBj.jpg);background-repeat:repeat-x;height:25px;border-top:1px solid #ccc; margin-top:3px;}
5 .dlAdvClose{ /*width:auto; display:block;*/ font-size:12px; font-family:"宋体"; cursor:pointer;background-image:url(dlClosebutton.jpg); background-repeat:no-repeat; display:block;width:52px; height:19px; margin:0 auto; margin-top:3px;color:#7f7c7c; padding-left:8px; font-weight:bold; padding-top:1px; text-align:center; line-height:19px;}
插件的调用
1 $(function(){
2 $.dLAdv({leftAdvStr:1,leftType:0,rightAdvStr:1,rightType:1});
3 })
给页面一个div,让它撑出滚动条.
1 <div style="height:10000px;"> div>