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