Javascript实现仿WebQQ界面的“浮云”兼容 IE7以上版本及FF


Posted in Javascript onApril 27, 2011

上图片素材先:

背景图片:
Javascript实现仿WebQQ界面的“浮云”兼容 IE7以上版本及FF
浮云图片: ←——————————这里是有图片D~ 全选就能看见了(因为背景是白的,云也是白的嘛~)……
CSS代码:

<style type="text/css"> 
* 
{ 
margin: 0; 
padding: 0; 
} 
body 
{ 
background: url("Images/body_bg.jpg") repeat center 0 fixed; 
} 
.cloud 
{ 
background: url("Images/cloud1.png"); 
height: 250px; 
width: 580px; 
position: absolute; 
} 
.hScroll 
{ 
overflow: hidden; 
} 
</style>

理解: .hScroll 是为了让浏览器的滚动条隐藏;其他一看就明白咋回事,我也不废话了;
body里的代码:
<body onload="StartMove()"> 
<div class="cloud" id="moveCloud"> 
</div> 
</body>

理解:页面加载的时候调用StarMove()函数;
Javascript代码:
<script language="javascript" type="text/javascript"> 
var cloud = null; 
var left = 0; 
document.documentElement.className = "hScroll"; 
function StartMove() { 
cloud = document.getElementById("moveCloud"); 
setInterval(Move, 100); 
} 
function Move() { 
left += 1; 
cloud.style.left = left + "px"; 
if (left >= (screen.width)) { 
left = -580; 
} 
} 
</script>

理解:document.documentElement.className = "hScroll"; 是调用css样式中的代码,目的是为了隐藏浏览器的滚动条(废话……上面不是说过了嘛^_^|| )
首先,我们要获取“浮云”层的id,所以用到了 cloud = document.getElementById("moveCloud"); cloud是一个全局变量,上面已经定义过了,所以在这里可以直接使用(老鸟勿喷,给新鸟看的).
然后再给他一个“计时器” setInterval(Move, 100); 调用100毫秒调用一次Move函数;
left += 1;等价于left=left+1; 配合上面的函数(每100毫秒调用一次嘛~)使用,然后再赋值给“浮云”层原来的坐标;所以写成了cloud.style.left = left + "px" ;
神马?你问我left是什么东东?他是css样式里的position的属性啊!不信你在DW里写个position冒号一下,看他出来不?
if (left >= (screen.width)) ; left = -580; 就是断判如果“浮云”移动(距离左边)的位置大于或者等于屏幕的宽度,我们就让他从头开始,把left的值设为-580;
为啥设-580?? 看CSS里面嘛,浮云的图片大小是580*250嘛,也就是他的长度是580px;所以把他设成-580是为了让它从右开始一点点显示,不然一上来就显示整张图片,多吓人啊~
废了半天话,不知道大家(和我一样菜的)看懂了没有,下面的是完整的代码,另存为.html文件试一下吧;图片自己下载,别忘了改路径!
完整代码:
<!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> 
<title>背景图片移动</title> 
<style type="text/css"> 
* 
{ 
margin: 0; 
padding: 0; 
} 
body 
{ 
background: url("Images/body_bg.jpg") repeat center 0 fixed; 
} 
.cloud 
{ 
background: url("Images/cloud1.png"); 
height: 250px; 
width: 580px; 
position: absolute; 
} 
.hScroll 
{ 
overflow: hidden; 
} 
</style> 
<script language="javascript" type="text/javascript"> 
var cloud = null; 
var left = 0; 
document.documentElement.className = "hScroll"; 
function StartMove() { 
cloud = document.getElementById("moveCloud"); 
setInterval(Move, 100); 
} 
function Move() { 
left += 1; 
cloud.style.left = left + "px"; 
if (left >= (screen.width)) { 
left = -580; 
} 
} 
</script> 
</head> 
<body onload="StartMove()"> 
<div class="cloud" id="moveCloud"> 
</div> 
</body> 
</html>
Javascript 相关文章推荐
jquery获取tr中控件值并操作tr实现思路
Mar 27 Javascript
Jquery getJSON方法详细分析
Dec 26 Javascript
原生js和jquery中有关透明度设置的相关问题
Jan 08 Javascript
node.js中的fs.stat方法使用说明
Dec 16 Javascript
JavaScript基本语法讲解
Jun 03 Javascript
jQuery中$.ajax()和$.getJson()同步处理详解
Aug 12 Javascript
详解JavaScript常量定义
Jan 03 Javascript
详解Vue组件之间的数据通信实例
Jun 17 Javascript
JS弹窗 JS弹出DIV并使整个页面背景变暗功能的实现代码
Apr 21 Javascript
Vue+Jwt+SpringBoot+Ldap完成登录认证的示例代码
May 21 Javascript
vue-router动态设置页面title的实例讲解
Aug 30 Javascript
jQuery 常用特效实例小结【显示与隐藏、淡入淡出、滑动、动画等】
May 19 jQuery
js,jQuery 排序的实现代码,网页标签排序的实现,标签排序
Apr 27 #Javascript
javascript中的继承实例代码
Apr 27 #Javascript
各浏览器对link标签onload/onreadystatechange事件支持的差异分析
Apr 27 #Javascript
仅IE9/10同时支持script元素的onload和onreadystatechange事件分析
Apr 27 #Javascript
js实时监听文本框状态的方法
Apr 26 #Javascript
Javascript中的window.event.keyCode使用介绍
Apr 26 #Javascript
Javascript中正则表达式的全局匹配模式分析
Apr 26 #Javascript
You might like
PHP 反射机制实现动态代理的代码
2008/10/22 PHP
php curl 伪造IP来源的实例代码
2012/11/01 PHP
php stripslashes和addslashes的区别
2014/02/03 PHP
php实现递归与无限分类的方法
2015/02/16 PHP
php实现判断访问来路是否为搜索引擎机器人的方法
2015/04/15 PHP
PHP递归实现快速排序的方法示例
2017/12/18 PHP
jQuery 1.5最新版本的改进细节分析
2011/01/19 Javascript
自定义ExtJS控件之下拉树和下拉表格附源码
2013/10/15 Javascript
jQuery中animate动画第二次点击事件没反应
2015/05/07 Javascript
Vue.js基础知识小结
2017/01/13 Javascript
jQuery UI Grid 模态框中的表格实例代码
2017/04/01 jQuery
JS实现简单的天数计算器完整实例
2017/04/28 Javascript
JavaScript 基础表单验证示例(纯Js实现)
2017/07/20 Javascript
webpack4的迁移的使用方法
2018/05/25 Javascript
vue中格式化时间过滤器代码实例
2019/04/17 Javascript
node 解析图片二维码的内容代码实例
2019/09/11 Javascript
策略模式实现 Vue 动态表单验证的方法
2019/09/16 Javascript
JS removeAttribute()方法实现删除元素的某个属性
2021/01/11 Javascript
CentOS安装pillow报错的解决方法
2016/01/27 Python
Python实现连接postgresql数据库的方法分析
2017/12/27 Python
替换python字典中的key值方法
2018/07/06 Python
Python 动态导入对象,importlib.import_module()的使用方法
2019/08/28 Python
CSS3 @media的基本用法总结
2019/09/10 HTML / CSS
CSS3 rgb and rgba(透明色)的使用详解
2020/09/25 HTML / CSS
浅谈移动端网页图片预加载方案
2018/11/05 HTML / CSS
保加利亚运动鞋购物网站:SneakerStudio.bg
2020/12/23 全球购物
德国珠宝和配件商店:Styleserver
2021/02/23 全球购物
2014年会演讲稿范文
2014/01/06 职场文书
投标担保书范文
2014/04/02 职场文书
爱护公物主题班会
2015/08/17 职场文书
2016年秋季运动会广播稿
2015/12/21 职场文书
2016年妇联“6﹒26国际禁毒日”宣传活动总结
2016/04/05 职场文书
高考升学宴主持词
2019/06/21 职场文书
浅谈Python数学建模之整数规划
2021/06/23 Python
JMeter对MySQL数据库进行压力测试的实现步骤
2022/01/22 MySQL
使用Django框架创建项目
2022/06/10 Python