JavaScript实现上下浮动的窗口效果代码


Posted in Javascript onOctober 12, 2015

本文实例讲述了JavaScript实现上下浮动的窗口效果代码。分享给大家供大家参考。具体如下:

这里介绍使用JavaScript实现上下浮动的窗口,在垂直方向上漂浮,代码内的JS函数有超丰富的浮动层定义功能,像浮动层位置高度、初始化事件触发器、设定浮动层为可见,用style.left设定浮动层左边距、浮动层的运动速度等,还有更多的设置选项都能实现。

运行效果截图如下:

JavaScript实现上下浮动的窗口效果代码

在线演示地址如下:

具体代码如下:

<HTML>
<HEAD>
<TITLE>上下浮动的窗口</TITLE>
<style type="text/css">
<!--
a:hover{color:00ff00}
a {color:000000;text-decoration:none}
-->
</style>
</HEAD>
<BODY>
<div id="floatpoint" STYLE="position:absolute;visibility:visible;">
<!--两个DIV之间放上你需要显示的内容-->
<table border=1 cellspacing="0" cellpadding="0" bordercolorlight="#000000" bordercolor="#FFFFFF">
 <tr>
    <td align=center bgcolor=#E3E3E3 style="color:HIGHLIGHTTEXT">
  <font color="#000000">
    最新消息!</font>
    </td>
 </tr>
 <tr>
    <td bgcolor=WINDOW style="font-size:9pt;color:WINDOWTEXT">
    <a href="#" target="_blank">三水点靠木</a><br>
    <div></div>
    </td>
 </tr>
</table>
<!--两个DIV之间放上你需要显示的内容-->
</div>
<script LANGUAGE="JavaScript1.2">
//这部分为用户自定义区
var XX=10; // 浮动层的X坐标,即左边距
var xstep=1; // 移动步长,此参数越小,移动越平滑,最小值为1
var delay_time=60; // 每步的时间间隔,此参数越小,移动速度越快
//以下部分请勿随意改动
var YY=0; 
var ch=0;
var oh=0;
var yon=0;
var ns4=document.layers?1:0 //判断浏览器类型是否是NS4
var ie=document.all?1:0 //判断浏览器类型是否是IE
var ns6=document.getElementById&&!document.all?1:0 //判断浏览器类型是否是NS6
if(ie){ //如果是IE
YY=document.body.clientHeight; //由clientHeight取得页面的高度
floatpoint.style.top=YY; //将浮动层位置调整到页面底部
}
else if (ns4){ //如果是NS4
YY=window.innerHeight; //由innerHeight取得页面的高度
document.floatpoint.pageY=YY; //将浮动层位置调整到页面底部
document.floatpoint.visibility="hidden"; //将浮动层隐藏。
}
else if (ns6){ //如果是NS6
YY=window.innerHeight //由innerHeight取得页面的高度
document.getElementById('floatpoint').style.top=YY //将浮动层位置调整到页面底部
}
function reloc1(){
if(yon==0){YY=YY-xstep;} //如果当前应该上移,则减小YY值
else{YY=YY+xstep;} //否则增加YY值下移
if (ie){ //如果是IE
ch=document.body.clientHeight; //取页面高度
oh=floatpoint.offsetHeight; //取浮动层的高度
}
else if (ns4){ //如果是NS4
ch=window.innerHeight; //取页面高度
oh=document.floatpoint.clip.height; //取浮动层的高度
}
else if (ns6){ //如果是NS6
ch=window.innerHeight //取页面高度
oh=document.getElementById("floatpoint").offsetHeight //取浮动层的高度
}
if(YY<0){yon=1;YY=0;} //如果浮动层超出了上界,则设定移动方向为向下;并设定层的位置为正好在上界处
if(YY>=(ch-oh)){yon=0;YY=(ch-oh);} //如果浮动层超出了下界,则设定移动方向为向上;并设定层的位置为正好在下界处
if(ie){ //如果是IE
floatpoint.style.left=XX; //用style.left设定浮动层左边距
floatpoint.style.top=YY+document.body.scrollTop; //用style.top设定浮动层上边距
}
else if (ns4){ //如果是NS4
document.floatpoint.pageX=XX; //用.pageX设定浮动层左边距
document.floatpoint.pageY=YY+window.pageYOffset; //用.pageY设定浮动层上边距
}
else if (ns6){ //如果是NS6
document.getElementById("floatpoint").style.left=XX
document.getElementById("floatpoint").style.top=YY+window.pageYOffset
}
}
function onad(){
if(ns4) //如果是NS4
document.floatpoint.visibility="visible"; //设定浮动层为可见
loopfunc(); //开始主循环,以不断改变浮动层位置
}
function loopfunc(){
reloc1(); //调整浮动层位置
setTimeout('loopfunc()',delay_time); //设定下一次调整的延时
}
if (ie||ns4||ns6)
window.onload=onad //初始化事件触发器
</script>
</BODY>
</HTML>

希望本文所述对大家的JavaScript程序设计有所帮助。

Javascript 相关文章推荐
DHTML Slide Show script图片轮换
Mar 03 Javascript
javascript十个最常用的自定义函数(中文版)
Sep 07 Javascript
javascript 实现键盘上下左右功能的小例子
Sep 15 Javascript
jQuery解决$符号命名冲突
Jun 18 Javascript
关于JS中二维数组的声明方法
Sep 24 Javascript
利用angular.copy取消变量的双向绑定与解析
Nov 25 Javascript
详解在vue-cli项目中使用mockjs(请求数据删除数据)
Oct 23 Javascript
JS实现自定义弹窗功能
Aug 08 Javascript
js使用swiper实现层叠轮播效果实例代码
Dec 12 Javascript
详解elementui之el-image-viewer(图片查看器)
Aug 30 Javascript
javascript的delete运算符知识点总结
Nov 19 Javascript
Vue 实现创建全局组件,并且使用Vue.use() 载入方式
Aug 11 Javascript
javascript函数式编程程序员的工具集
Oct 11 #Javascript
深入探讨javascript函数式编程
Oct 11 #Javascript
Javascript函数式编程语言
Oct 11 #Javascript
Javascript函数式编程简单介绍
Oct 11 #Javascript
jQuery实现仿新浪微博浮动的消息提示框(可智能定位)
Oct 10 #Javascript
JS+DIV+CSS排版布局实现美观的选项卡效果
Oct 10 #Javascript
JS实现漂亮的窗口拖拽效果(可改变大小、最大化、最小化、关闭)
Oct 10 #Javascript
You might like
十大催泪虐心动漫,你能坚持看到第几部?
2020/03/04 日漫
php+xml编程之SimpleXML的应用实例
2015/01/24 PHP
Yii模型操作之criteria查找数据库的方法
2016/07/15 PHP
Laravel中日期时间处理包Carbon的简单使用
2017/09/21 PHP
javascript 学习之旅 (2)
2009/02/05 Javascript
JS页面延迟执行一些方法(整理)
2013/11/11 Javascript
javascript实现iframe框架延时加载的方法
2014/10/30 Javascript
js全选按钮的实现方法
2015/11/17 Javascript
深入理解Node.js的HTTP模块
2016/10/12 Javascript
js获取当前页的URL与window.location.href简单方法
2017/02/13 Javascript
JS变量中有var定义和无var定义的区别以及es6中let命令和const命令
2017/02/19 Javascript
JS实现DOM删除节点操作示例
2018/04/04 Javascript
Vuex的初探与实战小结
2018/11/26 Javascript
使用vue中的混入mixin优化表单验证插件问题
2019/07/02 Javascript
vue实现移动端拖动排序
2020/08/21 Javascript
原生JS实现音乐播放器的示例代码
2021/02/25 Javascript
[04:14]从西雅图到上海——玩家自制DOTA2主题歌曲应援TI9
2019/07/11 DOTA
Python 用户登录验证的小例子
2013/03/06 Python
python求解水仙花数的方法
2015/05/11 Python
python爬虫爬取快手视频多线程下载功能
2018/02/28 Python
python3爬取数据至mysql的方法
2018/06/26 Python
Python 十六进制整数与ASCii编码字符串相互转换方法
2018/07/09 Python
django多种支付、并发订单处理实例代码
2019/12/13 Python
英国皇家造币厂:The Royal Mint
2018/10/05 全球购物
TUMI香港官网:国际领先的行李箱、背囊品牌
2021/03/01 全球购物
中专自荐信
2013/10/13 职场文书
计算机相关的自我评价
2014/01/15 职场文书
《再别康桥》教学反思
2014/02/12 职场文书
信息科学与技术专业求职信范文
2014/02/20 职场文书
给校长的建议书300字
2014/05/16 职场文书
企业管理标语
2014/06/10 职场文书
建筑节能汇报材料
2014/08/22 职场文书
物理分数没达标检讨书
2014/09/13 职场文书
2019年公司卫生管理制度样本
2019/08/21 职场文书
Java 数组内置函数toArray详解
2021/06/28 Java/Android
Java 写一个简单的图书管理系统
2022/04/26 Java/Android