手风琴特效

之前做了一个简单手风琴特效,用了html排版,css样式,还有js的事件,当然,手风琴的话,用纯css也是可以写出来的.我这里还是用了js.

image.png

简单来说就是当鼠标移到相应图片上时,改变width的属性.

首先写页面内容:,在body标签里面放一个盒子和一个列表就可以了:

显示html的代码:

<div id="frame">
    <div id="content">
        <ul class="clearfix">
            <li>
                <p><span>我的个人拉萨之旅丨丨故事之城</span></p>
            </li>
            <li>
                <p><span>我的个人拉萨之旅丨丨故事之城</span></p>
            </li>
            <li>
                <p><span>我的个人拉萨之旅丨丨故事之城</span></p>
            </li>
            <li>
                <p><span>我的个人拉萨之旅丨丨故事之城</span></p>
            </li>
        </ul>
    </div>
</div>

接下来是css的样式:

<style>
    * {
        padding: 0;
        margin: 0;
    }
            
    li {
        list-style: none;
    }
    
    body {
        background: url(img/1_bg.jpg) no-repeat center top;
    }
    
    #frame {
        height: 430px;
        width: 1089px;
        margin: 200px auto 0;
    }
            
    #content {
        height: 100%;
        width: 100%;
        overflow: hidden;
    }
            
    #content ul {
        width: 200%;
    }
            
    #content li {
        float: left;
        position: relative;
        height: 430px;
        width: 100px;
        background-image: url(img/2_1.jpg);
    }
            
    #content li:nth-child(1) {
        background-image: url(img/2_1.jpg);
    }
            
    #content li:nth-child(2) {
                background-image: url(img/4_2.jpg);
    }
            
    #content li:nth-child(3) {
        background-image: url(img/5_3.jpg);
    }
            
    #content li:nth-child(4) {
        background-image: url(img/6_4.jpg);
    }
            
    #content li p {
        position: absolute;
        left: 0;
        top: 0;
        width: 100px;
        height: 100%;
        background-color: rgba(0, 0, 0, .5);
    }
            
    #content li p span {
        display: block;
        width: 14px;
        font-size: 14px;
        margin: 20px auto 0;
        color: #fff;
    }
            
    .clearfix:after {
        content: "";
        display: block;
        clear: both;
    }
</style>

最后就是js事件了:

<script type="text/javascript">
    $(function() {
        var $content = $("#content");
        var $list = $content.find("ul li");
        $list.last().css("width", "789px");
        $list.hover(function() {
            $(this).stop().animate({
                width: 789 + "px"
            }).siblings().stop().animate({
                width: 100 + "px"
            })
        });
    });
</script>

在这里我的是鼠标的hover事件,也就是鼠标悬停事件,在这里可以改为点击事件,这个根据自己的需求来.

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 前端开发面试题 面试题目: 根据你的等级和职位的变化,入门级到专家级,广度和深度都会有所增加。 题目类型: 理论知...
    怡宝丶阅读 2,655评论 0 7
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    love2013阅读 2,397评论 0 11
  • 1. tab列表折叠效果 html: 能源系统事业部 岗位名称: 工作地点 岗位名...
    lilyping阅读 1,981评论 0 1
  • 前端开发知识点 HTML&CSS对Web标准的理解、浏览器内核差异、兼容性、hack、CSS基本功:布局、盒子模型...
    Hebborn_hb阅读 879评论 0 1
  • 看了两场电影,才明白生命中最重要的能力是爱的能力。没有爱,生活就没有温度。
    三木_d240阅读 169评论 0 1

友情链接更多精彩内容