Наш традиционный внешний интерфейс использует javascript для реализации различных сложных анимаций.После перехода на Css3 и анимации, разработка внешнего интерфейса имеет более высокую степень свободы и шаблонов в анимации, и разработка анимации становится все проще и проще. В этой статье давайте обобщим различные специальные эффекты, реализованные с помощью Css3. Эта статья ссылается на книгу «Секрет CSS» и сделала собственное резюме, надеясь сделать всех более полезными, и я настоятельно рекомендую всем прочитать эту книгу, вы это заслужили.
мы узнаем
- Css3
- outline
- radial-gradient
- linear-gradient
- box-shadow
Обязательна к прочтению программистам
1. Реализуйте внутреннюю пунктирную границу
основной кодТочка знаний: план
.dash-border{
width: 200px;
height: 100px;
line-height: 100px;
outline: 1px dashed #fff;
outline-offset: -10px;
}
2. Реализация закругленных углов в бордюре
основной кодТочка знаний: box-shadow
.radius-border{
margin-top: 20px;
width: 180px;
height: 80px;
box-shadow: 0 0 0 10px gray;
}
3. Реализовать полосатый фон и индикатор выполнения
основной кодОчки знаний: линейный градиент, повторяющийся линейный градиент
/* 上 */
background: linear-gradient(to right,#fb3 50%,#58a 0);
background-size: 40px 100%;
box-shadow: inset 0 0 3px #555;
/* 中 */
background: linear-gradient(45deg,#fb3 25%,#58a 0,#58a 50%,#fb3 0,#fb3 75%,#58a 0);
background-size: 40px 40px;
/* 下 (可以实现任意角度的渐变,45°时显示效果最好) */
background: repeating-linear-gradient(60deg,#fb3,#fb3 15px,#58a 0,#58a 30px);
4. Сложные фоновые узоры
Точки знаний: линейный градиент, повторяющийся линейный градиент, радиальный градиент
Поскольку вторая картинка будет иметь сложную случайную анимацию, рекомендуется попробовать ее самостоятельно, чтобы увидеть эффект, основной код
<style>
.bg-grid{
margin-top: 20px;
width: 200px;
height: 200px;
background-image: linear-gradient(rgba(255,255,255,1) 2px,transparent 0),
linear-gradient(to right,rgba(255,255,255,1) 2px,transparent 0),
linear-gradient(rgba(255,255,255,.2) 1px,transparent 0),
linear-gradient(to right,rgba(255,255,255,.2) 1px,transparent 0);
background-position: -50px -50px;
background-size: 100px 100px,100px 100px, 100% 10px, 10px 100%;
}
.animate-grid{
animation: move-grid 6s linear infinite;
}
@keyframes move-grid{
0%{
background-position: -50px -50px;
}
30%{
background-position: -100px -100px;
}
60%{
background-position: -100px -150px;
}
100%{
background-position: -50px -50px;
}
}
</style>
<div class="bg-grid black-theme"></div>
<div class="bg-grid black-theme animate-grid"></div>
Случайная анимация движения светофоров и красных уличных фонарей
Используйте мультифон и позицию css3 для реализации движения светофоров и цветных блоков фона.основной код
<style>
.bg-dot{
margin-top: 20px;
width: 200px;
height: 50px;
background-image: radial-gradient(circle,#0cf 15px,transparent),
radial-gradient(circle,red 15px,transparent),
radial-gradient(circle,yellow 15px,transparent),
radial-gradient(circle,green 15px,transparent);
background-repeat: no-repeat;
background-position: 0 0, 50px 0, 100px 0, 150px 0, 200px 0;
background-size: 50px 50px;
}
.animate-dot{
animation: move-dot 8s linear infinite;
}
.animate-dot2{
animation: move-dot2 6s linear infinite;
}
@keyframes move-dot{
0%{
background-position: 0 0, 50px 0, 100px 0, 150px 0;
}
30%{
background-position: 50px 0, 0 0, 100px 0, 150px 0;
}
60%{
background-position: 50px 0, 100px 0, 0 0, 150px 0;
}
100%{
background-position: 50px 0, 100px 0, 150px 0, 0 0;
}
}
@keyframes move-dot2{
0%{
background-image: radial-gradient(circle,#0cf 15px,transparent),
radial-gradient(circle,gray 15px,transparent),
radial-gradient(circle,gray 15px,transparent),
radial-gradient(circle,gray 15px,transparent);
}
30%{
background-image: radial-gradient(circle,gray 15px,transparent),
radial-gradient(circle,red 15px,transparent),
radial-gradient(circle,gray 15px,transparent),
radial-gradient(circle,gray 15px,transparent);
}
60%{
background-image: radial-gradient(circle,gray 15px,transparent),
radial-gradient(circle,gray 15px,transparent),
radial-gradient(circle,yellow 15px,transparent),
radial-gradient(circle,gray 15px,transparent);
}
100%{
background-image: radial-gradient(circle,gray 15px,transparent),
radial-gradient(circle,gray 15px,transparent),
radial-gradient(circle,gray 15px,transparent),
radial-gradient(circle,green 15px,transparent);
}
}
</style>
<div class="bg-dot black-theme animate-dot"></div>
<div class="bg-dot black-theme animate-dot2"></div>
Фон шахматной доски и случайная анимация фона шахматной доски
Узор в виде шахматной доски с использованием фонового градиентаосновной код
<style>
.bg-qi{
margin-top: 20px;
width: 200px;
height: 200px;
background-color: #eee;
background-image: linear-gradient(45deg,rgba(0,0,0,.25) 25%,transparent 0,transparent 75%,rgba(0,0,0,.25) 0),
linear-gradient(45deg,rgba(0,0,0,.25) 25%,transparent 0,transparent 75%,rgba(0,0,0,.25) 0);
background-position: 0 0, 20px 20px;
background-size: 40px 40px;
box-shadow: 2px 2px 4px rgba(0,0,0,.4);
}
</style>
<div class="bg-qi black-theme"></div>
псевдослучайный фон
Используйте фоновые градиенты и анимацию ключевых кадров для создания сложных псевдослучайных анимаций.основной код
<style>
.bg-line-rand{
margin-top: 20px;
width: 480px;
height: 60px;
background-color: #eee;
background-image: linear-gradient(90deg,#fb3 11px, transparent 0),
linear-gradient(90deg,#ab4 23px, transparent 0),
linear-gradient(90deg,#655 41px, transparent 0);
background-size: 41px 100%, 61px 100%, 83px 100%;
box-shadow: 2px 2px 4px rgba(0,0,0,.4);
}
.bg-dot-rand{
margin-top: 20px;
width: 200px;
height: 200px;
background-color: #eee;
background-image: radial-gradient(circle,#fb3 5px, transparent 0),
radial-gradient(circle,#ab4 13px, transparent 0),
radial-gradient(circle,#655 31px, transparent 0);
background-repeat: no-repeat;
background-size: 101px 203px, 147px 60px, 373px 201px;
box-shadow: 2px 2px 4px rgba(0,0,0,.4);
}
.animate1{
animation: move 4s linear infinite;
}
.animate2{
animation: move2 4s linear infinite;
}
@keyframes move{
0%{
background-position: 0 0, 0 0, 0 0;
}
50%{
background-position: -10px 0, 20px 0, 30px 0;
}
100%{
background-position: 0 0, 30px 0, 10px 0;
}
}
@keyframes move2{
0%{
background-position: 0 0, 0 0, 0 0;
}
50%{
background-position: -10px 30px, 20px 0, -40px 80px;
}
100%{
background-position: 0 20px, 60px -20px, 10px 30px;
}
}
</style>
<div class="bg-line-rand black-theme"></div>
<div class="bg-line-rand black-theme animate1"></div>
<div class="bg-dot-rand black-theme animate2"></div>
5. Угловой эффект
Точка знаний: линейный градиент
основной код
<style>
.fold{
margin-left: auto;
margin-right: auto;
margin-bottom: 20px;
width: 200px;
height: 80px;
color: #fff;
line-height: 80px;
text-align: center;
background: linear-gradient(to left bottom,transparent 50%,rgba(0,0,0,.5) 0) no-repeat 100% 0 / 2em 2em,
linear-gradient(-135deg,transparent 1.4em,#06c 0);
}
.linear{
background: linear-gradient(to left bottom,transparent 50%,rgba(0,0,0,.5)) no-repeat 100% 0 / 2em 2em,
linear-gradient(-135deg,transparent 1.4em,#06c);
}
</style>
<div class="fold">折角效果哦</div>
<div class="fold linear">折角效果哦</div>
2. Эффект скругления внутренней тени
основной код
<style>
.fold-1{
margin-left: auto;
margin-right: auto;
margin-bottom: 20px;
position: relative;
width: 200px;
height: 80px;
border-radius: .5em;
color: #fff;
line-height: 80px;
text-align: center;
background: linear-gradient(-150deg,transparent 1.5em, #58a 0);
}
.fold-1::before{
content: "";
position: absolute;
top: 0;
right: 0;
background: linear-gradient(to left bottom,transparent 50%,rgba(0,0,0,.2) 0,rgba(0,0,0,.4)) 100% 0 no-repeat;
width: 1.73em;
height: 3em;
transform: translateY(-1.3em) rotate(-30deg);
transform-origin: bottom right;
border-bottom-left-radius: inherit;
box-shadow: -.2em .2em .3em -.1em rgba(0,0,0,.15);
}
</style>
<div class="fold-1">折角效果哦</div>
6. Полосатый фон для адаптивного текста
Точки знаний: линейный градиент, высота строки, происхождение фона
основной код
<style>
.stripe-bg{
padding: .5em;
line-height: 1.5em;
background: beige;
background-size: auto 3em;
background-origin: content-box;
background-image: linear-gradient(rgba(0,0,0,.2) 50%, transparent 0);
}
.stripe-bg > p{
margin: 0;
}
</style>
<div class="stripe-bg">
<p>hello you</p>
<p>hello you</p>
<p>hello you</p>
<p>hello you</p>
<p>hello you</p>
</div>
7. Реализация пользовательского подчеркивания
Линейный градиент точки знаний
Вы, ребята, заметили? Подчеркивание по умолчанию будет пересекать текст, а указанное выше — нет!
основной код
<style>
.my-line{
line-height: 1.4em;
background: linear-gradient(gray,gray) no-repeat;
background-size: 100% 1px;
background-position: 0 1.15em;
text-shadow: .05em 0 #fff, -.05em 0 #fff;
}
</style>
<div class=""><span class="my-line">i have your big apple.you have a too? hi hi hi.</span></div>
наконец
Автор запустит CMS с открытым исходным кодом через 3 дня.Техническая архитектура выглядит следующим образом:
- Бэкэнд-узел+Коа+redis+JsonSchema
- Фоновый интерфейс управления vue-cli3 + vue + ts + vuex + antd-vue + axios
- Клиентский интерфейс react + antd + react-hooks + axios
Идея дизайна, архитектура и процесс реализации системы будут представлены позже.Приглашаем ознакомиться с более подробным введением в паблике «Интересный интерфейс».
Мы приглашаем всех учиться друг у друга и вместе исследовать границы интерфейса.
больше рекомендаций
- Вспомните проблему межстраничной связи в старом проекте и фронтальную реализацию функции скачивания файлов
- Как элегантно использовать javascript для рекурсивного рисования дерева структуры
- 5 минут, чтобы научить вас писать фиктивный сервер данных с помощью nodeJS
- Реализация и применение javascript-версии декартова произведения
- Реализация и применение бинарного дерева и бинарного дерева поиска в JavaScript
- Реализация небольшой игры на проигрывателе с помощью JavaScript и C3
- Научу вас использовать 200 строк кода, чтобы написать любовную мини-игру Dou Pin Le H5 (с исходным кодом)
- Изучение и обобщение решений для внешней интеграции на основе экологии react/vue.
- 9012 научит вас, как использовать gulp4 для разработки шаблонов проекта.
- Как написать собственную библиотеку js менее чем из 200 строк кода)
- Краткое изложение часто используемых js-функций, позволяющих мгновенно повысить эффективность работы (постоянно обновляется)
- Картинка, чтобы научить вас быстро играть в vue-cli3
- 3 минуты, чтобы научить вас использовать нативный js для реализации компонента предварительного просмотра загрузки файлов с мониторингом прогресса
- 3 минуты, чтобы научить вас использовать нативный js для реализации компонента предварительного просмотра загрузки файлов с мониторингом прогресса
- Использование Angular8 и API карты Baidu для разработки «списка туров»
- js реализация базового алгоритма поиска и тест производительности при 1,7 миллионах данных
- Как сделать интерфейсный код в 60 раз быстрее
- "Серия интерфейсных алгоритмов" Дедупликация массива
- Vue advanced advanced series — играйте с vue и vuex с машинописным текстом
- Три года в авангарде, расскажите о 5 самых стоящих книгах, которые стоит прочитать