zoukankan      html  css  js  c++  java
  • HTML5 CSS3专题 纯CSS打造相册效果

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/30993277

    今天偶然发现电脑里面还有这样的一个例子,感觉效果还不错,不记得啥时候下载的了,也好久没上w3cfuns了,怀念学习前台的日子,给大家分享下。

    效果图:


    效果是不是还是很不错的,最主要的是没有使用一行js,这才是亮点。

    先看html文件:

    <body>
    
    <div id="gallery">
        <h1>纯CSS3相册效果</h1>
        <ul>
    
            <li>
                <span class="touch"><img src="images/pic1.jpg"/></span>
    
                <div style="display: block;">
                    <img src="images/pic1.jpg"/>
                </div>
            </li>
    
            <li>
                <span><img src="images/pic2.jpg"/></span>
    
                <div>
                    <img src="images/pic2.jpg"/>
                </div>
            </li>
            <li>
                <span><img src="images/pic3.jpg"/></span>
    
                <div>
                    <img src="images/pic3.jpg"/>
                </div>
            </li>
    
            <li>
                <span><img src="images/pic4.jpg"/></span>
    
                <div>
                    <img src="images/pic4.jpg"/>
                </div>
            </li>
    
            <li>
                <span><img src="images/pic5.jpg"/></span>
    
                <div>
                    <img src="images/pic5.jpg"/>
                </div>
            </li>
    
    
        </ul>
    
        <div class="clearfix"></div>
    </div>
    
    
    </body>

    简单描述一下:

    1、ul 中 li决定了照片的个数

    2、ul使用样式float:right,140px;使得显示在相册的右侧区域

    3、li的float:left,使得li可以左浮动;li中存放大图的div,position为absolute会根据div#gallary进行定位,默认只有第一个显示

    4、当鼠标移动到li上时,改变li span img的透明度和li div的display将大图显示


    接下来就是css文件:

    <style type="text/css">
    
            body
            {
                font-family: "微软雅黑";
            }
    
            #gallery
            {
                 700px;
                position: relative;
                margin: 20px auto 0;
                background-color: #000;
                min-height: 400px;
                padding: 20px;
            }
    
                /*标题*/
            #gallery h1
            {
                color: #fff;
                font-size: 2em;
                font-weight: bold;
            }
    
            #gallery ul
            {
                 140px;
                float: right;
                margin: 10px 0 20px;
            }
    
            #gallery ul li
            {
                float: left;
                margin: 20px 8px 0 0;
            }
    
            #gallery ul li span
            {
                display: block;
                position: relative;
                 60px;
                height: 80px;
                border: 1px solid #fff;
                -moz-border-radius: 4px;
                -webkit-border-radius: 4px;
                -ms-border-radius: 4px;
                -o-border-radius: 4px;
                border-radius: 4px;
                overflow: hidden;
            }
    
            #gallery  ul li span img
            {
                position: relative;
                top: -200px;
                left: -100px;
                filter: alpha(opacity=30);
                opacity: 0.3;
            }
    
            #gallery ul li span.touch img, #gallery ul li:hover span img
            {
                opacity: 1;
                filter: alpha(opacity=100);
            }
    
            #gallery ul li:hover div
            {
                display: block;
            }
    
            #gallery ul li div  img
            {
                 460px;
                height: 288px;
            }
    
            #gallery ul li div
            {
                display: none;
                position: absolute;
                top: 100px;
                left: 30px;
                border: 5px solid #fff;
            }
    
            .clearfix
            {
                clear: both;
            }
    
    
        </style>

    css中没有什么复杂的样式,就不做描述了。此外html中我引入了一个重置样式的css , reset.css ,大家也可以使用自己习惯的重置样式:

    html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend{
    	margin: 0;
    	padding: 0;
    	font-size: 100%;
    	border: 0;
    	outline: 0;
    	background: transparent;
    	}
    	
    ol, ul {
    	list-style: none;
    	}
    
    blockquote, q {
    	quotes: none;
    	}
    
    :focus {
    	outline: 0;
    	}
    
    table {
    	border-collapse: collapse;
    	border-spacing: 0;
    	}


    源码点击下载

    版权声明:本文为博主原创文章,未经博主允许不得转载。

  • 相关阅读:
    我读过的书 编程爱好者
    HarmonyOS ListContainer基础用法
    HarmonyOS ListContainer 读取网络json数组
    HarmonyOS Activity页面跳转
    HarmonyOS ListContainer 图文并排
    HarmonyOS 线性布局练习一 登录页面
    jsonserver 环境搭建及使用方法
    HarmonyOS 真机调试
    在win下设置C语言环境变量
    使用 Eclipse 调试 Java 程序的 10 个技巧
  • 原文地址:https://www.cnblogs.com/dingxiaoyue/p/4924939.html
Copyright © 2011-2022 走看看