js+css实现三种瀑布流布局方式15种图片布局进入动画效果代码

代码语言:html

所属分类:瀑布流

代码描述:js+css实现三种瀑布流布局方式15种图片布局进入动画效果代码

代码标签: 瀑布 布局 方式 15种 图片 布局 进入 动画 效果

下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开

<!DOCTYPE html>
<html lang="en" class="no-js">

<head>
   
<meta charset="UTF-8" />
   
<meta name="viewport" content="width=device-width, initial-scale=1">
   
<style>
       
*,
   
*::after,
   
*::before {
       
-webkit-box-sizing: border-box;
       
box-sizing: border-box;
   
}
   
    body
{
       
font-family: 'Roboto Mono', monospace;
       
font-size: 14px;
       
font-weight: 500;
       
color: #82888a;
       
background: #2c2d31;
       
overflow-x: hidden;
       
-webkit-font-smoothing: antialiased;
   
}
   
   
.js .loading::before,
   
.js .loading::after {
       
content: '';
       
position: fixed;
       
z-index: 1000;
   
}
   
   
.loading::before {
       
top: 0;
       
left: 0;
       
width: 100%;
       
height: 100%;
       
background: #2c2d31;
   
}
   
   
.loading::after {
       
top: 50%;
       
left: 50%;
       
width: 40px;
       
height: 40px;
       
margin: -20px 0 0 -20px;
       
border: 8px solid #383a41;
       
border-bottom-color: #565963;
       
border-radius: 50%;
       
animation: animLoader 0.8s linear infinite forwards;
   
}
   
   
@keyframes animLoader {
        to
{ transform: rotate(360deg); }
   
}
   
    a
{
       
text-decoration: none;
       
color: #f2f2f2;
       
outline: none;
   
}
   
   
a:hover,
   
a:focus {
       
color: #e6629a;
   
}
   
   
.hidden {
       
position: absolute;
       
overflow: hidden;
       
width: 0;
       
height: 0;
       
pointer-events: none;
   
}
   
    main
{
       
display: flex;
       
flex-wrap: wrap;
   
}
   
   
/* Icons */
   
.icon {
       
display: block;
       
width: 1.5em;
       
height: 1.5em;
       
margin: 0 auto;
       
fill: currentColor;
   
}
   
   
.content--side {
       
position: relative;
       
z-index: 100;
       
width: 15vw;
       
min-width: 130px;
       
max-height: 100vh;
       
padding: 0 1em;
       
order: 2;
   
}
   
   
.content--center {
       
flex: 1;
       
max-width: calc(100vw - 260px);
       
order: 3;
   
}
   
   
.content--right {
       
order: 4;
   
}
   
   
.content--related {
       
display: flex;
       
flex-wrap: wrap;
       
justify-content: center;
       
width: 100%;
       
padding: 8em 1em 3em;
       
text-align: center;
       
order: 5;
   
}
   
   
.media-related {
       
width: 100%;
   
}
   
   
.media-item {
       
padding: 1em;
   
}
   
   
.media-item__img {
       
max-width: 100%;
       
opacity: 0.7;
       
transition: opacity 0.3s;
   
}
   
   
.media-item:hover .media-item__img,
   
.media-item:focus .media-item__img {
       
opacity: 1;
   
}
   
   
.media-item__title {
       
font-size: 1em;
       
max-width: 220px;
       
padding: 0.5em;
       
margin: 0 auto;
   
}
   
   
/* Header */
   
.codrops-header {
       
position: relative;
       
z-index: 100;
       
display: flex;
       
align-items: center;
       
width: 100%;
       
padding: 3em 1em 4em;
       
order: 1;
   
}
   
   
.codrops-header__title {
       
font-size: 1em;
       
font-weight: normal;
       
flex: 1;
       
margin: 0 7em 0 0;
       
text-align: center;
       
text-transform: lowercase;
   
}
   
   
.codrops-header__title::before,
   
.codrops-header__title::after {
       
font-size: 22px;
       
font-weight: bold;
       
display: inline-block;
       
padding: 0 0.25em;
       
color: #42454c;
   
}
   
   
.codrops-header__title::after {
       
content: '\2309';
       
vertical-align: sub;
   
}
   
   
.codrops-header__title::before {
       
content: '\230A';
   
}
   
   
/* GitHub corner */
   
.github-corner {
       
position: absolute;
       
top: 0;
       
right: 0;
   
}
   
   
.github-corner__svg {
       
fill: #82888a;
       
color: #2c2d31;
       
position: absolute;
       
top: 0;
       
border: 0;
       
right: 0;
   
}
   
   
.github-corner:hover .octo-arm {
       
animation: octocat-wave 560ms ease-in-out;
   
}
   
   
@keyframes octocat-wave {
       
0%,
       
100% {
               
transform: rotate(0);
       
}
       
20%,
       
60% {
               
transform: rotate(-25deg);
       
}
       
40%,
       
80% {
               
transform: rotate(10deg);
       
}
   
}
   
   
@media (max-width:500px) {
       
.github-corner:hover .octo-arm {
               
animation: none;
       
}
       
.github-corner .octo-arm {
               
animation: octocat-wave 560ms ease-in-out;
       
}
   
}
   
   
   
/* Top Navigation Style */
   
.codrops-links {
       
position: relative;
       
display: flex;
       
justify-content: space-between;
       
align-items: center;
       
height: 2.75em;
       
margin: 0 0 0 2.25em;
       
text-align: center;
       
white-space: nowrap;
       
background: #1f2125;
   
}
   
   
.codrops-links::after {
       
content: '';
       
position: absolute;
       
top: -10%;
       
left: calc(50% - 1px);
       
width: 2px;
       
height: 120%;
       
background: #2c2d31;
       
transform: rotate3d(0,0,1,22.5deg);
   
}
   
   
.codrops-icon {
       
display: inline-block;
       
padding: 0 0.65em;
   
}
   
   
/* Controls */
   
.control--grids {
       
margin: 0 0 2.5em;
       
text-align: right;
   
}
   
   
.control__title {
       
font-size: 0.85em;
       
display: block;
       
width: 100%;
       
margin: 0 0 1em;
       
color: #e6629a;
   
}
   
   
.control__item {
       
position: relative;
       
display: block;
       
margin: 0 0 0.5em;
   
}
   
   
.control__radio {
       
position: absolute;
       
z-index: 10;
       
top: 0;
       
left: 0;
       
width: 100%;
       
height: 100%;
       
cursor: pointer;
       
opacity: 0;
   
}
   
   
.control__label {
       
white-space: nowrap;
   
}
   
   
.control__radio:checked + .control__label {
       
color: #fff;
       
background: #673ab7;
   
}
   
   
.control__radio:not(:checked):hover + .control__label,
   
.control__btn:hover {
       
color: white;
   
}
   
   
.control__btn {
       
display: block;
       
width: 100%;
       
margin: 0 0 0.5em;
       
padding: 0;
       
text-align: left;
       
color: inherit;
       
border: none;
       
background: none;
   
}
   
   
.control__btn:focus {
       
outline: none;
   
}
   
   
/* Grid */
   
   
.grid {
       
position: relative;
       
z-index: 2;
       
display: block;
       
margin: 0 auto;
   
}
   
   
.grid--hidden {
       
position: fixed !important;
       
z-index: 1;
       
top: 0;
       
left: 0;
       
width: 100%;
       
pointer-events: none;
       
opacity: 0;
   
}
   
   
.js .grid--loading::before,
   
.js .grid--loading::after {
       
content: '';
       
z-index: 1000;
   
}
   
   
.js .grid--loading::before {
       
position: fixed;
       
top: 0;
       
left: 0;
       
width: 100vw;
       
height: 100vh;
       
background: #2c2d31;
   
}
   
   
.js .grid--loading::after {
       
position: absolute;
       
top: calc(25vh - 20px);
       
left: 50%;
       
width: 40px;
       
height: 40px;
       
margin: 0 0 0 -20px;
       
border: 8px solid #383a41;
       
border-bottom-color: #565963;
       
border-radius: 50%;
       
animation: animLoader 0.8s linear forwards infinite;
   
}
   
   
.grid__sizer {
       
margin-bottom: 0 !important;
   
}
   
   
.grid__link,
   
.grid__img {
       
display: block;
   
}
   
   
.grid__img {
       
width: 100%;
   
}
   
   
.grid__deco {
       
position: absolute;
       
top: 0;
       
left: 0;
       
pointer-events: none;
   
}
   
   
.grid__deco path {
       
fill: none;
       
stroke: #fff;
       
stroke-width: 2px;
   
}
   
   
.grid__reveal {
       
position: absolute;
       
z-index: 50;
       
top: 0;
       
left: 0;
       
width: 100%;
       
height: 100%;
       
pointer-events: none;
       
opacity: 0;
       
background-color: #2c2d31;
   
}
   
   
.grid .grid__item,
   
.grid .grid__sizer {
       
width: calc(50% - 20px);
       
margin: 0 10px 20px;
   
}
   
   
@media screen and (min-width: 60em) {
       
.grid .grid__item,
       
.grid .grid__sizer {
               
width: calc((100% / 3) - 20px);
               
margin: 0 10px 20px;
       
}
   
}
   
   
@media screen and (min-width: 70em) {
       
.grid .grid__item,
       
.grid .grid__sizer {
               
width: calc(25% - 30px);
               
margin: 0 15px 30px;
       
}
       
/* Grid types */
       
.grid--type-b .grid__item,
       
.grid--type-b .grid__sizer {
               
width: calc(20% - 20px);
               
margin: 0 10px 20px;
       
}
   
       
.grid--type-c .grid__item,
       
.grid--type-c .grid__sizer {
               
width: calc(25% - 16px);
               
margin: 0 8px 16px;
       
}
   
}
   
   
@media screen and (max-width: 50em) {
        main
{
               
display: block;
       
}
       
.codrops-header {
               
padding: 1em;
               
flex-wrap: wrap;
       
}
       
.codrops-links {
               
margin: 0;
       
}
       
.codrops-header__title {
               
width: 100%;
               
text-align: left;
               
flex: none;
               
margin: 1em 0;
       
}
       
.content--side {
               
width: 100%;
       
}
       
.content--right {
               
order: 3;
       
}
       
.content--center {
               
max-width: 100vw;
       
}
       
.control {
               
margin: 0 0 1em;
               
text-align: left;
       
}
       
.control__item,
       
.control__btn {
               
display: inline-block;
       
}
       
.control__btn {
               
width: auto;
       
}
   
}
   
.pater {
       
position: relative;
       
display: block;
       
overflow: hidden;
       
width: 100%;
       
padding: 0 0 1em;
       
background: #fff;
   
}
   
   
.pater,
   
.pater:focus,
   
.pater:hover {
       
color: #2c2d31;
   
}
   
   
.pater::after {
       
content: 'Sponsor';
       
font-size: 0.765em;
       
position: absolute;
       
z-index: 20;
       
bottom: 0;
       
left: 0;
       
padding: 1em;
       
color: #f1bed4;
   
}
   
   
.pater__img {
       
width: 100%;
       
height: 120px;
       
background: url() no-repeat center center;
       
background-size: cover;
   
}
   
   
.pater__content {
       
font-size: 0.85em;
       
z-index: 9;
       
padding: 1.5em 1em;
       
text-align: center;
   
}
   
   
.pater__title {
       
font-size: 1em;
       
margin: 0;
       
color: #ca6694;
   
}
   
   
.pater__call {
       
font-weight: bold;
   
}
   
   
@media screen and (min-width: 50em) {
       
.pater {
               
height: 240px;
               
background: #1f2125;
       
}
       
.pater--small {
               
height: 200px;
       
}
       
.pater,
       
.pater:focus,
       
.pater:hover {
               
color: #82888a;
       
}
       
.pater__img {
               
position: absolute;
               
z-index: 10;
               
top: 0;
               
left: 0;
               
height: 100%;
       
}
       
.pater__call {
               
color: #fff;
       
}
       
/* Hover Animation */
       
.pater__img,
       
.pater__content,
       
.pater::after {
               
transition: transform 0.3s, opacity 0.3s;
       
}
   
       
.pater:hover::after {
               
opacity: 0;
               
transform: translate3d(0,20px,0);
       
}
   
       
.pater:hover .pater__img {
               
transform: translate3d(0,100px,0) scale3d(0.7,0.7,1);
       
}
   
       
.pater--small:hover .pater__img {
               
transform: translate3d(0,100%,0);
       
}
   
       
.pater__content {
               
position: absolute;
               
top: 50px;
               
left: 0;
               
width: 100%;
               
height: 100%;
       
}
   
       
.pater--small .pater__content {
               
display: flex;
               
flex-direction: column;
               
justify-content: center;
       
}
   
       
.pater:hover .pater__content {
               
transform: translate3d(0,-50px,0);
       
}
   
}
   
</style>

   
<script>
        document
.documentElement.className = 'js';
   
</script>

</head>

<body class="loading">

   
<main>
       
<header class="codrops-header"></header>
       
<div class="content content--side">
           
<div class="control control--grids">
               
<span class="control__title">switch layout</span>
               
<div class="control__item">
                   
<input class="control__radio" type="radio" name="grid-type" value="grid--type-a" id="control-grid-a" checked>
                   
<label class="control__label" for="control-grid-a">grid A</label>
               
</div>
               
<div class="control__item">
                   
<input class="control__radio" type="radio" name="grid-type" value="grid--type-b" id="control-grid-b">
                   
<label class="control__label" for="control-grid-b">grid B</label>
               
</div>
               
<div class="control__item">
                   
<input class="control__radio" type="radio" name="grid-type" value="grid--type-c" id="control-grid-c">
                   
<label class="control__label" for="control-grid-c">grid C</label>
               
</div>
           
</div>
       
</div>
       
<div class="content content--side content--right">
           
<div class="control control--effects">
     .........完整代码请登录后点击上方下载按钮下载查看

网友评论0