原生js编写焦点图效果


Posted in Javascript onDecember 08, 2016

自己用原生js写的简单焦点图,算是对原生js初步运用。

原生js编写焦点图效果

html部分

<div class="focusPicture">
          <section class="mPhoto" id="mPhoto">
            <img src="images/20161021/b_5809b93b66d18.jpg"/>
          </section><!-- 主要的大图 -->
          <section class="oPhoto">
            <div class="imgWrap">
              <section class="on">
                <img src="images/20161021/b_5809b93b66d18.jpg"/>
              </section>
              <section>
                <img src="images/20161021/b_5809b96c4da53.jpg"/>
              </section>
              <section>
                <img src="images/20161021/b_5809b9bea39c4.jpg"/>
              </section>
              <section>
                <img src="images/20161021/b_5809ba288384e.jpg"/>
              </section>
              <section>
                <img src="images/20161021/b_5809bae42fa81.jpg"/>
              </section>
              <section>
                <img src="images/20161021/b_5809ba288384e.jpg"/>
              </section>
              <section>
                <img src="images/20161021/b_5809bb3da0bbc.jpg"/>
              </section>
            </div>
          </section><!-- 其他的小图 -->
          <section class="prevNext">
            <div class="prev">
              <i></i>
            </div><!-- 上一张 -->
            <div class="next">
              <i></i>
            </div><!-- 下一张 -->
          </section><!-- 上下翻页 -->
</div><!-- 焦点图区 -->

js部分

window.onload = function(){


 /*焦点图特效*/
 var mPhoto = document.getElementById("mPhoto");
 var imgWrap = document.getElementsByClassName("imgWrap")[0];
 var wrapSize = 4; /*图片容器最大显示图片数*/
 if(imgWrap.getElementsByTagName("section").length>wrapSize){
  imgWrap.innerHTML = imgWrap.innerHTML+imgWrap.innerHTML;
 }
 
 var oImages = imgWrap.getElementsByTagName("section");
 for(var i = 0 ; i<oImages.length; i++)
 {
  oImages[i].onmouseover = function()
  {
   for(var j = 0 ; j<oImages.length; j++)
   {
    removeClass(oImages[j],"on");
   }
   var imgSrc = this.getElementsByTagName("img")[0].src;
   addClass(this,"on");
   mPhoto.getElementsByTagName("img")[0].src = imgSrc;
  }
 }


 /*上下翻页容器*/
 var oPrevNext = document.getElementsByClassName("prevNext")[0];
 var oPrev = oPrevNext.getElementsByClassName("prev")[0];
 var oNext = oPrevNext.getElementsByClassName("next")[0];
 var oImageHeight = oImages[0].getElementsByTagName("img")[0].height||0;
 var oPositionTop = imgWrap.offsetTop;
 var imgIndex = 0;
 
 if(oImages.length>wrapSize*2)
 {
  oPrev.style.display = "block";
  oNext.style.display = "block";
 }
 
 /*上一页*/
 oPrev.onclick=function()
 {
  imgIndex-=1;
  if(imgIndex<=0){
   imgIndex = 6;
  }


  var oTop = imgIndex*(oImageHeight+8);
  imgWrap.style.top = -oTop+"px";
  
  /*获取当前图片的索引*/
  for(var i = 0 ; i<oImages.length; i++)
  {
   var oBol = hasClass(oImages[i],"on")||false;
   if(oBol){
    var index = oIndex(oImages[i],oImages);
    index=index-1;
    if(imgIndex==6){
     index = 6;
    }
    for(var j = 0 ; j<oImages.length; j++)
    {/*清除其他的图片on样式*/
     removeClass(oImages[j],"on");
    }
    addClass(oImages[index],"on");
    var imgSrc = oImages[index].getElementsByTagName("img")[0].src;
    mPhoto.getElementsByTagName("img")[0].src = imgSrc;


    return false;
   }
  }
 }
 
 /*下一页*/
 oNext.onclick = function()
 {
  imgIndex+=1;
  if(imgIndex>=6){
   imgIndex = 0;
  }
  var oTop = imgIndex*(oImageHeight+8);
  imgWrap.style.top = -oTop+"px";
  
  /*获取当前图片的索引*/
  for(var i = 0 ; i<oImages.length; i++)
  {
   var oBol = hasClass(oImages[i],"on")||false;
   if(oBol){
    var index = oIndex(oImages[i],oImages);
    index=index+1;
    if(imgIndex==0){
     index = 1;
    }
    for(var j = 0 ; j<oImages.length; j++)
    {/*清除其他的图片on样式*/
     removeClass(oImages[j],"on");
    }
    addClass(oImages[index],"on");
    var imgSrc = oImages[index].getElementsByTagName("img")[0].src;
    mPhoto.getElementsByTagName("img")[0].src = imgSrc;


    return false;
   }
  }


 }
}


function hasClass(element,cName)
{//检查class是否存在
 return !!element.className.match(new RegExp('(\\s|^)'+cName+'(\\s|$)'));
}
function addClass(element,cName)
{//添加一个class
 if(!hasClass(element,cName))
 {
  element.className +=' '+cName;
 }
}
function removeClass(element,cName)
{//移除一个class
 if(hasClass(element,cName))
 {
  element.className = element.className.replace(new RegExp('(\\s|^)'+cName+'(\\s|$)'),' ');
 }
}


function oIndex(current, obj)
{/*获取索引*/
 for (var i = 0, length = obj.length; i<length; i++)
 { 
  if (obj[i] == current)
  { 
   return i; 
  } 
 } 
}

css部分

.productInfo .focusPicture{
 width: 698px;
 float: left;
 position: relative;
 border-right: 1px solid #d9cdb4;
}
.productInfo .focusPicture .mPhoto{
 width: 542px;
 height: 360px;


}
.productInfo .focusPicture .mPhoto img{
 width: 100%;
 height: 100%;
}


.productInfo .focusPicture .oPhoto{
 width: 128px;
 height: 352px;
 position: absolute;
 right: 14px;
 top: 4px;
 overflow: hidden;


}


.productInfo .oPhoto div{
 width: 128px;
 position: absolute;
 left:0;
 top:0;
 -webkit-transition: top .2s ease-out;
 -moz-transition: top .2s ease-out;
 transition: top .2s ease-out; 
}
.productInfo .oPhoto section{
 height: 78px;
 margin: 8px 0;
 position: relative;
 cursor: pointer;
}
.productInfo .oPhoto section::before {
 content: "";
 display: block;
 width: 100%;
 height: 100%;
 background-color: rgba(255,255,255,.42);
 position: absolute;
 left: 0;
 top: 0;
}


.productInfo .oPhoto section.on::before{
 display: none;
}


.productInfo .focusPicture .oPhoto img{
 width: 100%;
 height: 100%;
}


.productInfo .focusPicture .prevNext{
 width: 32px;
 height: 32px;
 position: absolute;
 top: -4px;
 right: 62px;
}


.productInfo .prevNext div.prev,
.productInfo .prevNext div.next{
 width: 32px;
 height: 32px;
 -webkit-border-radius: 50%;
 -moz-border-radius: 50%;
 border-radius: 50%;
 background-color: #fff;
 position: absolute;
 left: 0;
 -webkit-transition: all .25s;
 -moz-transition: all .25s;
 transition: all .25s;
 display: none;
 cursor: pointer;
}
.productInfo .prevNext div.prev{
 top: 0;
 box-shadow: 0 -2px 4px rgba(0,0,0,.24);


}
.productInfo .prevNext div.next{
 top: 336px;
 box-shadow: 0 2px 4px rgba(0,0,0,.24);
}


.productInfo .prevNext div.prev:hover{
 box-shadow: 2px -2px 3px rgba(0,0,0,.24);


}
.productInfo .prevNext div.next:hover{
 box-shadow: -2px 2px 3px rgba(0,0,0,.24);
}


.productInfo .prevNext div.prev i,
.productInfo .prevNext div.next i{
 width: 16px;
 height: 16px;
 position: absolute;
 top: 0;
 right: 0;
 bottom: 0;
 left: 0;
 margin: auto;
 cursor: pointer;
}
.productInfo .prevNext div.prev i{
 background: url(../images/arrows-icon.png) 0 -16px no-repeat;
 background-size: 48px 32px;
 bottom: 2px;
}


.productInfo .prevNext div.next i{
 background: url(../images/arrows-icon.png) 0 0 no-repeat;
 background-size: 48px 32px;
 top: 2px;
}


.productInfo .prevNext div.prev:hover i,
.productInfo .prevNext div.next:hover i{
 -webkit-transform: scale(1.1);
 -moz-transform: scale(1.1);
 transform: scale(1.1);
}


.productInfo .prevNext div.prev:hover i{
 background: url(../images/arrows-icon.png) -16px -16px no-repeat;
 background-size: 48px 32px;
}


.productInfo .prevNext div.next:hover i{
 background: url(../images/arrows-icon.png) -16px 0px no-repeat;
 background-size: 48px 32px;
}


.productInfo .prevNext div.prev:active i{
 background: url(../images/arrows-icon.png) -32px -16px no-repeat;
 background-size: 48px 32px;
}


.productInfo .prevNext div.next:active i{
 background: url(../images/arrows-icon.png) -32px 0px no-repeat;
 background-size: 48px 32px;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS保留两位小数 四舍五入函数的小例子
Nov 20 Javascript
Jquery实现侧边栏跟随滚动条固定(兼容IE6)
Apr 02 Javascript
JavaScript常用的返回,自动跳转,刷新,关闭语句汇总
Jan 13 Javascript
基于jQuery实现搜索关键字自动匹配功能
Mar 26 Javascript
关于javascript中dataset的问题小结
Nov 16 Javascript
AngularJS ng-mousedown 指令
Aug 02 Javascript
JS实现拖动滚动条评分的效果代码分享
Sep 29 Javascript
javascript中Number的方法小结
Nov 21 Javascript
Bootstrap 响应式实用工具实例详解
Mar 29 Javascript
安装vue-cli报错 -4058 的解决方法
Oct 19 Javascript
关于Vue的路由权限管理的示例代码
Mar 06 Javascript
JavaScript实现学生在线做题计时器功能
Dec 05 Javascript
JavaScript中${pageContext.request.contextPath}取值问题及解决方案
Dec 08 #Javascript
微信小程序开发之录音机 音频播放 动画实例 (真机可用)
Dec 08 #Javascript
Vue自定义指令介绍(2)
Dec 08 #Javascript
JS实现页面进入和返回定位到具体位置
Dec 08 #Javascript
解析利用javascript如何判断一个数为素数
Dec 08 #Javascript
微信小程序开发之大转盘 仿天猫超市抽奖实例
Dec 08 #Javascript
微信开发之调起摄像头、本地展示图片、上传下载图片实例
Dec 08 #Javascript
You might like
PHP编程之高级技巧——利用Mysql函数
2006/10/09 PHP
谈谈新手如何学习PHP
2006/12/23 PHP
Zend Framework实现多服务器共享SESSION数据的方法
2016/03/22 PHP
使用Jquery打造最佳用户体验的登录页面的实现代码
2011/07/08 Javascript
jQuery设置和移除文本框默认值的方法
2015/03/09 Javascript
js中数组的常用方法小结
2016/12/30 Javascript
微信小程序使用image组件显示图片的方法【附源码下载】
2017/12/08 Javascript
基于react后端渲染模板引擎noox发布使用
2018/01/11 Javascript
vue.js学习笔记之v-bind和v-on解析
2018/05/03 Javascript
微信小程序 textarea 层级过高问题简单解决方案
2019/10/14 Javascript
Jquery Datatables的使用详解
2020/01/30 jQuery
vue切换菜单取消未完成接口请求的案例
2020/11/13 Javascript
Python入门篇之面向对象
2014/10/20 Python
在Python中操作时间之mktime()方法的使用教程
2015/05/22 Python
Python实现二叉搜索树
2016/02/03 Python
python将unicode转为str的方法
2017/06/21 Python
Linux下Pycharm、Anaconda环境配置及使用踩坑
2018/12/19 Python
详解Python连接MySQL数据库的多种方式
2019/04/16 Python
解决pycharm导入本地py文件时,模块下方出现红色波浪线的问题
2020/06/01 Python
经验丰富程序员才知道的8种高级Python技巧
2020/07/27 Python
pycharm 2020 1.1的安装流程
2020/09/29 Python
西班牙购买行李箱和背包网站:Maletas Greenwich
2019/10/08 全球购物
关联、聚合(Aggregation)以及组合(Composition)的区别
2012/02/29 面试题
家长通知书教师评语
2014/04/17 职场文书
工地门卫岗位职责范本
2014/07/01 职场文书
法人代表身份证明书及授权委托书
2014/09/16 职场文书
民政局副局长民主生活会个人对照检查材料
2014/09/19 职场文书
2015年预算员工作总结
2015/05/14 职场文书
班主任开场白
2015/06/01 职场文书
六一文艺汇演主持词
2015/06/30 职场文书
2016道德模范先进事迹材料
2016/02/26 职场文书
MATLAB 如何求取离散点的曲率最大值
2021/04/16 Python
解析在浏览器地址栏输入一个URL后发生了什么
2021/06/21 Servers
Golang中channel的原理解读(推荐)
2021/10/16 Golang
Win11 KB5015814遇安装失败 影响开始菜单性能解决方法
2022/07/15 数码科技
JS前端宏任务微任务及Event Loop使用详解
2022/07/23 Javascript