仿淘宝幻灯片,基础版,后期效果是要做到每次点击小圆点,切换都无缝

 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN"
"http://www.w3.org/TR/html4/strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>4.淘宝幻灯片</title>
<meta name="author" content="Administrator" />
<!-- Date: 2014-12-11 -->
<style>
*{margin:0;padding:0}
#div1{width:400px;height:215px; border:1px solid red;margin:40px auto; overflow:hidden;position:relative }
ul{position:absolute;left:0;top:0}
li{list-style:none;float:left; position: relative}
li.active{background:red}
li.active2{border:1px solid red}
li img{width:400px;}
ol{position:absolute}
ol li{width:15px;height:15px;border-radius:10px;background:#808080;margin:0 3px}
.t{position:absolute;font-size:80px;z-index:2;left:200px;top:100px;color:red;width:100px;height:100px;background:#fff;text-align:center; border:1px solid black}
</style>
<script>
window.onload=function(){
var oDiv1=document.getElementById('div1');
var oUl=oDiv1.getElementsByTagName('ul')[0];
var aLi=oUl.getElementsByTagName('li');
var arr=['3-images/1.jpg','3-images/2.jpg','3-images/3.jpg','3-images/4.jpg','3-images/5.jpg'];
var arr1=['1','2','3','4','5'];
oUl.style.width = aLi.length * aLi[0].offsetWidth +'px'; var oL=document.createElement('ol');
var str='';
for( var i=0;i<aLi.length;i++ ){ str += '<li></li>'
}
oL.innerHTML=str;
oDiv1.appendChild( oL );
document.title = oDiv1.offsetWidth +'-'+oL.offsetWidth;
oL.style.left = (oDiv1.offsetWidth - oL.offsetWidth)/2 +'px';
oL.style.bottom='0px';
var aLi1=oL.getElementsByTagName('li'); var timer=null;
var num=0; function init(){
for(var i=0;i<aLi1.length;i++){
aLi1[i].className=''
}
aLi1[num].className='active'
}
init();
function slide(){
num++;
if(num>=aLi.length) {
num=0;
oUl.style.left = 0;
}
init();
hcMove(oUl,{
'left':-400*num
})
}
timer=setInterval(function(){
slide()
},1000) oDiv1.onmouseover=function(){
clearInterval(timer)
}
oDiv1.onmouseout=function(){
timer=setInterval(function(){
slide()
},1000)
}
for(var i=0;i<aLi.length;i++){
aLi1[i].index=i;
aLi1[i].onclick=function(){
num = this.index;
init();
hcMove(oUl,{'left':-400*num})
}
} }
function css(obj,attr) {
return obj.currentStyle ? obj.currentStyle[attr] : getComputedStyle(obj)[attr]
}
/**完美 缓冲运动 带opacity**/
function hcMove(obj,json,fn){
clearInterval( obj.timer ); obj.timer=setInterval(function(){
var iBtn=true; for(var attr in json){
var target=json[attr]; if( attr == 'opacity' ){
var iSpeed = (target-Math.round(css(obj,attr))*100)/6;
}else{
var iSpeed = (target-parseInt(css(obj,attr)))/6;
} iSpeed = iSpeed > 0 ? Math.ceil(iSpeed) : Math.floor(iSpeed);//速度取整,因为js中的小数是经过计算的,默认四舍五入,但是不够0.5的就不会动了 if( parseInt(css(obj,attr)) != target ){
iBtn=false;//如果有运动没到达目标点,iBtn为false if( attr == 'opacity' ){
var sNow=Math.round(css(obj,attr)*100) + iSpeed; //先做处理 再赋值
if( sNow > target && iSpeed >0 || sNow < target && iSpeed <0 ){
sNow = target
} obj.style[attr] = sNow/100;
obj.style.filter = 'alpha(opacity='+sNow+')';
}else{ var sNow = parseInt(css(obj,attr)) + iSpeed; //先做处理 再赋值
if( sNow > target && iSpeed >0 || sNow < target && iSpeed <0 ){
sNow = target
}
obj.style[attr] = sNow +'px';
} } } if(iBtn){ //如果运动全部完成,iBtn为true
clearInterval(obj.timer);
fn && fn()
} },30)
} </script>
</head>
<body>
<div id="div1">
<ul>
<li mars='1'><img src="3-images/1.jpg"><span class="t">1</span></li>
<li mars='2'><img src="3-images/2.jpg"><span class="t">2</span></li>
<li mars='3'><img src="3-images/3.jpg"><span class="t">3</span></li>
<li mars='4'><img src="3-images/4.jpg"><span class="t">4</span></li>
<li mars='5'><img src="3-images/5.jpg"><span class="t">5</span></li>
</ul>
</div>
</body>
</html>

JS 仿淘宝幻灯片 非完整版 小案例的更多相关文章

  1. JS仿淘宝详情页菜单条智能定位效果

    类似于淘宝详情页菜单条智能定位 对于每个人来说并不陌生!如下截图所示:红色框的那部分! 基本原理: 是用JS侦听滚动事件,当页面的滚动距离(页面滚动的高度)大于或者等于 "对象"( ...

  2. 原生js仿淘宝手机购买选项代码

    这是一款基于原生js实现仿淘宝手机信息购买选项效果源码,界面整体效果仿照淘宝购物选项设计,点击不同选项还可实时显示不同的价格计算结果,界面简洁大方.美观实用.可兼容目前最新的各类主流浏览器. 在线演示 ...

  3. JS仿淘宝星星评价

    //直接复制过去就可以了(你也可以吧css和js封装成css和js文件导入). <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transit ...

  4. JS仿淘宝左侧菜单

    http://www.webdm.cn/webcode/1c724a06-06f4-4c4f-931a-c683285fa700.html

  5. js 实现淘宝无缝轮播图效果,可更改配置参数 带完整版解析代码[slider.js]

    前言:         本人纯小白一个,有很多地方理解的没有各位大牛那么透彻,如有错误,请各位大牛指出斧正!小弟感激不尽.         本篇文章为您分析一下原生JS写淘宝无缝轮播图效果 需求分析: ...

  6. js 实现淘宝放大镜功能,可更改配置参数 带完整版解析代码[magnifier.js]

    前言:         本人纯小白一个,有很多地方理解的没有各位大牛那么透彻,如有错误,请各位大牛指出斧正!小弟感激不尽.         本篇文章为您分析一下原生JS写淘宝放大镜效果 基本功能: 运 ...

  7. 基于Bootstrap仿淘宝分页控件实现

    .header { cursor: pointer } p { margin: 3px 6px } th { background: lightblue; width: 20% } table { t ...

  8. 一款基于jQuery仿淘宝红色分类导航

    今天给大家分享一款基于jQuery仿淘宝红色分类导航.这款分类导航适用浏览器:IE8.360.FireFox.Chrome.Safari.Opera.傲游.搜狗.世界之窗.效果图如下: 在线预览    ...

  9. jquery仿淘宝规格颜色选择效果

    jquery实现的仿淘宝规格颜色选择效果源代码如下 jquery仿淘宝规格颜色选择效果 -收缩HTML代码 运行代码 [如果运行无效果,请自行将源代码保存为html文件运行] <script t ...

随机推荐

  1. [Swift通天遁地]八、媒体与动画-(2)实现视频文件的播放和画中画

    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...

  2. [Swift通天遁地]九、拔剑吧-(2)在项目中使用大量美观的图标

    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...

  3. 什么是JavaScript对象?

    对象是JavaScript的基本数据类型.对象是一种复合值:它将很多值(原始值或者其他对象)聚合在一起,可通过名字访问这些值.对象也可看做是属性的无序集合,每个属性都是一个名/值对.属性名是字符串,因 ...

  4. glances内存分析工具使用

    glances -b 以字节为单位显示网络流量 glances 是一个命令行工具包括如下命令选项:-b:显示网络连接速度 Byte/ 秒-B @IP|host :绑定服务器端 IP 地址或者主机名称- ...

  5. JavaScript--innerHTML 属性

    innerHTML 属性用于获取或替换 HTML 元素的内容. 语法: Object.innerHTML 注意: 1.Object是获取的元素对象,如通过document.getElementById ...

  6. 【USACO2006 Mar】滑雪缆车 skilift

    [USACO2006 Mar] 滑雪缆车 skilift Time Limit 1000 msMemory Limit 131072 KBytes Description 科罗拉多州的罗恩打算为奶牛建 ...

  7. 题解报告:hdu 1233 还是畅通工程

    Problem Description 某省调查乡村交通状况,得到的统计表中列出了任意两村庄间的距离.省政府“畅通工程”的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能 ...

  8. Leetcode0143--Reorder List 链表重排

    [转载请注明]https://www.cnblogs.com/igoslly/p/9351564.html 具体的图示可查看 链接 代码一 /** * Definition for singly-li ...

  9. Android Studio 快捷键整理

    Alt+回车 导入包,自动修正 Ctrl+N   查找类Ctrl+Shift+N 查找文件Ctrl+Alt+L  格式化代码Ctrl+Alt+O 优化导入的类和包Alt+Insert 生成代码(如ge ...

  10. gtest ASSERT_TRUE和EXPECT_TRUE

    调用ASSERT_TRUE的函数,返回值类型定义必须是void,如果想返回别的类型,就用EXPECT_TRUE: void abc::fun() { ASSERT_TRUE(fun1()); } bo ...