最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

js实现可以点击收缩或张开的悬浮窗

来源:动视网 责编:小OO 时间:2020-11-27 22:29:43
文档

js实现可以点击收缩或张开的悬浮窗

本文实例为大家分享了js实现悬浮窗的具体代码,供大家参考,具体内容如下:说明:点击”+“按钮,悬浮窗收缩/展开。思路;1、在html中定义一个div块,定一个id;一个按钮,点击时用。2、写一个js,包含收缩以及展开的函数;为按钮添加点击事件。3、想要让悬浮窗好看点,可设置对应的参数。步骤;html;
推荐度:
导读本文实例为大家分享了js实现悬浮窗的具体代码,供大家参考,具体内容如下:说明:点击”+“按钮,悬浮窗收缩/展开。思路;1、在html中定义一个div块,定一个id;一个按钮,点击时用。2、写一个js,包含收缩以及展开的函数;为按钮添加点击事件。3、想要让悬浮窗好看点,可设置对应的参数。步骤;html;


本文实例为大家分享了js实现悬浮窗的具体代码,供大家参考,具体内容如下

说明:点击”+“按钮,悬浮窗收缩/展开

思路

1、在html中定义一个div块,定一个id;一个按钮,点击时用。

2、写一个js,包含收缩以及展开的函数;为按钮添加点击事件。

3、想要让悬浮窗好看点,可设置对应的参数。

步骤

html

 <div id="area">
 <div id="small_menu">
 <ul>
 <li><a href="#">item one</a></li>
 <li><a href="#">item two</a></li> 
 <li><a href="#">item three</a></li>
 <li><a href="#">item four</a></li>
 <li><a href="#">item five</a></li>
 </ul> 
 </div> 
 <div id="on" onclick="xuanfu();"><p>+</p></div> 
 </div>

js

var menubox = document.getElementById("area"); //area为菜单栏的id
 var cli_on = document.getElementById("on"); //on为按钮
 var flag = false, timer = null, initime = null, r_len = 0;

 if(menubox.style.right=== 0){
 flag = true;
 }
 else{
 flag = false;
 }
 cli_on.onclick = function () {
 //为on按钮绑定click事件
 clearTimeout(initime);
 //根据状态flag执开展开收缩
 if (flag) {
 r_len = 0;
 timer = setInterval(slideright, 10);
 } else {
 r_len = -160;
 timer = setInterval(slideleft, 10);
 }
 }
 //展开
 function slideright() {
 if (r_len <= -160) {
 clearInterval(timer);
 flag = !flag;
 return false;
 }else{
 r_len -= 5;
 menubox.style.right = r_len + 'px';
 }
 }
 //收缩
 function slideleft() {
 if (r_len >= 0) {
 clearInterval(timer);
 flag = !flag;
 return false;
 } else {
 r_len += 5;
 menubox.style.right = r_len + 'px';
 }
 } 

完整代码

含css,可直接用

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>悬浮窗</title>
</head>
<style type="text/css">
#area{
 position:fixed;
 width:160px;
 right:-160px;
 top:27%;}
#small_menu ul {
 list-style: none;
}
#area #on{
 position: absolute;
 top: 40%;
 right: 100%;
 width: 30px;
 height: 30px;
 cursor: pointer;
 border-radius: 15px;
 background-color: rgba(13, 143, 143, 0.2);
 }
#area #on p{
 font-size:30px;
 text-align:center;
 margin-top:-6px;
 color:#01E290;
 }
#area #small_menu {
 width:100%;
 } 
#area #small_menu ul li {
 width:100%;
 height: 44px;
 text-align:left;
 background-color: rgba(2, 27, 38, 0.62);
 border-top: 1px solid #043B46;
 line-height: 44px;
}
#area #small_menu ul li a{
 text-decoration: none; 
 margin-left:30px;
 color: #bfbfbf;
 font-size:16px;
 font-family: 'Microsoft Yahei';
 }
#area #small_menu li.active {
 width: 156px; 
 background-color: rgba(2, 27, 38, 0.87);
 border-left: 4px solid #00ffff;
 border-top: 0px;
}
#area #small_menu li.active a{
 color: #00ffff;
 }

#area #small_menu ul li:hover {
 width: 156px;
 background-color: rgba(2, 27, 38, 0.87);
 border-left: 4px solid #00ffff;

}
#area #small_menu ul li:hover a{
 color: #00ffff; 
 } 
</style>
<body>
 <div id="area">
 <div id="small_menu">
 <ul>
 <li><a href="#">item one</a></li>
 <li><a href="#">item two</a></li> 
 <li><a href="#">item three</a></li>
 <li><a href="#">item four</a></li>
 <li><a href="#">item five</a></li>
 </ul> 
 </div> 
 <div id="on" onclick="xuanfu();"><p>+</p></div> 
 </div>
<script>
//嵌套在页面中,文档初始化时加载。

 var menubox = document.getElementById("area"); //area为菜单栏的id
 var cli_on = document.getElementById("on"); //on为按钮
 var flag = false, timer = null, initime = null, r_len = 0;

 if(menubox.style.right=== 0){
 flag = true;
 }
 else{
 flag = false;
 }
 cli_on.onclick = function () {
 //为on按钮绑定click事件
 clearTimeout(initime);
 //根据状态flag执开展开收缩
 if (flag) {
 r_len = 0;
 timer = setInterval(slideright, 10);
 } else {
 r_len = -160;
 timer = setInterval(slideleft, 10);
 }
 }
 //展开
 function slideright() {
 if (r_len <= -160) {
 clearInterval(timer);
 flag = !flag;
 return false;
 }else{
 r_len -= 5;
 menubox.style.right = r_len + 'px';
 }
 }
 //收缩
 function slideleft() {
 if (r_len >= 0) {
 clearInterval(timer);
 flag = !flag;
 return false;
 } else {
 r_len += 5;
 menubox.style.right = r_len + 'px';
 }
 } 

</script>
</body>

</html>

小结到此。

文档

js实现可以点击收缩或张开的悬浮窗

本文实例为大家分享了js实现悬浮窗的具体代码,供大家参考,具体内容如下:说明:点击”+“按钮,悬浮窗收缩/展开。思路;1、在html中定义一个div块,定一个id;一个按钮,点击时用。2、写一个js,包含收缩以及展开的函数;为按钮添加点击事件。3、想要让悬浮窗好看点,可设置对应的参数。步骤;html;
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top