zoukankan      html  css  js  c++  java
  • [javascript] 封装一个实用的焦点图切换效果

    之前写过一篇博客,实用的焦点图切换效果,结构行为相分离 解释的比较详细,脚本是分离式的,但在易用性重用性方面并不理想,所以在原来的基础上改了下,封装起来,并做了进一步的优化,这样同一个页面就可以使用多个这样的效果了,xhtm和css没有变化,感兴趣的朋友可以在js上面可以跟之前的代码做个对比,这样更容易理解和掌握。
    有什么问题和建议请回帖 @&@

    1.xhtml

    <div class="jfocus">
    <div id="jfocuspic">
    <a href="#" style="display:block;">图片一</a>
    <a href="#">图片二</a>
    <a href="#">图片三</a>
    <a href="#">图片四</a>
    </div>
    <ul id="jfocusnum">
    <li class="on">1</li>
    <li>2</li>
    <li>3</li>
    <li>4</li>
    </ul>
    </div>


    2.css

    .jfocus{300px;height:300px;border:#ccc 1px solid;background-color:#FFF;}
    #jfocuspic{FILTER: progid:DXImageTransform.Microsoft.Fade (duration
    =0.5,overlap=1.0 );300px;height:200px;overflow:hidden;}
    #jfocuspic a{display:none; font
    -size:2em; text-align:center; line-height:200px; font-weight:bold; background-color:#CCC; height:200px; cursor:pointer;}
    #jfocusnum li{cursor:pointer;height:50px; 50px; line
    -height:50px;display:inline-block; color:#000; border:#999 1px solid; text-align:center; background-color:#CCC; float:left; margin:0 5px;}
    #jfocusnum li.on{color:#f00; font
    -weight:bold; border:#900 1px solid; font-size:14px;}

    3.js 

    function $(id,tag){var re=(id&&typeof id!="string")?id:document.getElementById(id);if(!tag){return re;}else{return re.getElementsByTagName(tag);}}//获取元素对象
    function FocusImg(focbox,picobj,numbox,numobj,time){
    var n
    =0;
    var imglist
    =$(focbox,picobj);
    var Num
    =$(numbox,numobj);
    function setBg(value){
    for(var i=0;i<Num.length;i++) Num[i].className=(value==i)?"on":"";}//设置字母列表的样式切换;
    function plays(value){
    if(document.all) $(focbox).filters[0].Apply();//滤镜
    for(i=0;i<Num.length;i++){i==value?imglist[i].style.display="block":imglist[i].style.display="none";}
    if(document.all) $(focbox).filters[0].play();
    }
    function mouse(n){
    //设置鼠标经过和离开后的事件;
    for(var i=0;i<Num.length;i++){
    (function(n){
    Num[i].onmouseover
    =imglist[i].onmouseover=function(){clearInterval(autoStart);Mea(n);}
    Num[i].onmouseout
    =imglist[i].onmouseout=function(){setAuto();}
    })(i);
    }
    }
    function Mea(value){n
    =value;mouse(n);setBg(value);plays(value);}
    function auto(){n
    ++;if(n>Num.length-1)n=0; Mea(n);}
    function setAuto(){autoStart
    =setInterval(function(){auto();},time)}
    setAuto();
    }

     在xhtml后调用函数,并传入对象参数:
    <script type="text/javascript">FocusImg("jfocuspic","a","jfocusnum","li",3000);</script>

    源代码: 

    <!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>实用的焦点图切换效果,分离式封装js脚本</title>
    <style type="text/css">
    .jfocus{300px;height:300px;border:#ccc 1px solid;background-color:#FFF;}
    #jfocuspic{FILTER: progid:DXImageTransform.Microsoft.Fade (duration=0.5,overlap=1.0 );300px;height:200px;overflow:hidden;}
    #jfocuspic a{display:none; font-size:2em; text-align:center; line-height:200px; font-weight:bold; background-color:#CCC; height:200px; cursor:pointer;}
    #jfocusnum li{cursor:pointer;height:50px; 50px; line-height:50px;display:inline-block; color:#000; border:#999 1px solid; text-align:center; background-color:#CCC; float:left; margin:0 5px;}
    #jfocusnum li.on{color:#f00; font-weight:bold; border:#900 1px solid; font-size:14px;}
    /*#jfocuspic{FILTER: progid:DXImageTransform.Microsoft.Wipe(GradientSize=1.0,motion=forward);水平方向渐变*/
    </style>
    <script language="JavaScript" type="text/javascript">
    function $(id,tag){var re=(id&&typeof id!="string")?id:document.getElementById(id);if(!tag){return re;}else{return re.getElementsByTagName(tag);}}
    function FocusImg(focbox,picobj,numbox,numobj,time){
    var n=0;
    var imglist=$(focbox,picobj);
    var Num=$(numbox,numobj);
    function setBg(value){	for(var i=0;i<Num.length;i++) Num[i].className=(value==i)?"on":"";}
    function plays(value){
    if(document.all) $(focbox).filters[0].Apply();
    for(i=0;i<Num.length;i++){i==value?imglist[i].style.display="block":imglist[i].style.display="none";}
    if(document.all) $(focbox).filters[0].play();
    }
    function mouse(n){
    	for(var i=0;i<Num.length;i++){
    		(function(n){
    		Num[i].onmouseover=imglist[i].onmouseover=function(){clearInterval(autoStart);Mea(n);}
    		Num[i].onmouseout=imglist[i].onmouseout=function(){setAuto();}
    		})(i);
    	}
    }
    function Mea(value){n=value;mouse(n);setBg(value);plays(value);}
    function auto(){n++;if(n>Num.length-1)n=0;	Mea(n);}
    function setAuto(){autoStart=setInterval(function(){auto();},time)}
    setAuto();
    }
    </script>
    </head>
    <body>
    <div class="jfocus">
        <div id="jfocuspic">
            <a href="#" style="display:block;">图片一</a>
            <a href="#">图片二</a>
            <a href="#">图片三</a>
            <a href="#">图片四</a>
        </div>
        <ul id="jfocusnum">
            <li class="on">1</li>
            <li>2</li>
            <li>3</li>
            <li>4</li>
        </ul>
    </div>
    <script type="text/javascript">FocusImg("jfocuspic","a","jfocusnum","li",3000);</script>
    </body>
    </html>
    


     与 实用的焦点图切换效果,结构行为相分离  对比一下

  • 相关阅读:
    Ubuntu Linux下的Wireshark使用drcom_2011.lua分析drcom协议
    Keil提示premature end of file错误 无法生成HEX文件
    Linux和win7(win10)双系统时间错误问题 时间相差8小时
    Wireshark使用drcom_2011.lua插件协助分析drcom协议
    Keil报错failed to execute 'd:KeilC51BINC51.EXE'
    第一篇博文
    LG 7078 贪吃蛇
    LG 1791 人员雇佣
    洛谷 2698 Flowerpot
    HDU 5965 扫雷
  • 原文地址:https://www.cnblogs.com/fengfan/p/1777153.html
Copyright © 2011-2022 走看看