整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

HTML5焦点图片波浪过渡效果切换动画特效源码

HTML5焦点图片波浪过渡效果切换动画特效源码

果图

各位观众大家好,今天给大家带来的是

HTML5焦点图片波浪过渡效果切换动画特效

是不是很炫酷!

代码过长需要文档版源码来我的前端群581549454,已上传到群文件

废话不多说上源码

网站样式源码:

<!doctype html>

<html>

<head>

<meta charset="utf-8">

<title>HTML5焦点图片波浪过渡效果切换动画特效</title>

<style>

* {

margin: 0;

padding: 0;

box-sizing: border-box;

}

.parent {

width: 681px;

height: 384px;

top: 0;

bottom: 0;

left: 0;

right: 0;

margin: auto auto;

overflow: hidden;

position: absolute;

-webkit-box-shadow: 0 0 88px 5px rgba(0, 0, 0, 0.75);

-moz-box-shadow: 0 0 88px 5px rgba(0, 0, 0, 0.75);

box-shadow: 0 0 88px 5px rgba(0, 0, 0, 0.75);

}

svg {

position: absolute;

z-index: 1;

width: 681px;

height: 384px;

}

button {

position: absolute;

z-index: 50;

width: 40px;

overflow: hidden;

height: 40px;

border: none;

border-radius: 50%;

background: #fff;

cursor: pointer;

-webkit-box-shadow: 0 0 88px 5px rgba(0, 0, 0, 0.75);

-moz-box-shadow: 0 0 88px 5px rgba(0, 0, 0, 0.75);

box-shadow: 0 0 88px 5px rgba(0, 0, 0, 0.75);

}

button:focus {

outline-width: 0;

}

circle {

stroke: #fff;

fill: none;

transition: 0.3s;

}

#svg1 circle {

transition-timing-function: linear;

}

#svg2 circle {

transition-timing-function: linear;

}

#Capa_1 {

position: absolute;

width: 16px;

height: 16px;

transform: translate(-7px, -8px);

}

#Capa_2 {

position: absolute;

width: 16px;

height: 16px;

transform: translate(-9px, -8px);

}

.right {

margin-left: 628px;

margin-top: 168px;

border: 1px solid #849494;

background-color: transparent;

transition: .5s;

}

.right:hover {

background-color: #fff;

}

.left {

margin-left: 0.5%;

margin-top: 6.17%;

border: 1px solid #849494;

background-color: transparent;

transition: .5s;

}

.left:hover {

background-color: #fff;

}

.circle1 {

transition-delay: 0.05s;

}

.circle2 {

transition-delay: 0.1s;

}

.circle3 {

transition-delay: 0.15s;

}

.circle4 {

transition-delay: 0.2s;

}

.circle5 {

transition-delay: 0.25s;

}

.circle6 {

transition-delay: 0.3s;

}

.circle7 {

transition-delay: 0.35s;

}

.circle8 {

transition-delay: 0.4s;

}

.circle9 {

transition-delay: 0.45s;

}

.circle10 {

transition-delay: 0.05s;

}

.circle11 {

transition-delay: 0.1s;

}

.circle12 {

transition-delay: 0.15s;

}

.circle13 {

transition-delay: 0.2s;

}

.circle14 {

transition-delay: 0.25s;

}

.circle15 {

transition-delay: 0.3s;

}

.circle16 {

transition-delay: 0.35s;

}

.circle17 {

transition-delay: 0.4s;

}

.circle18 {

transition-delay: 0.45s;

}

.slide1 {

background-image: url("img/1.jpg");

}

.slide2 {

background-image: url("img/2.jpg");

}

.slide3 {

background-image: url("img/3.jpg");

}

.slide4 {

background-image: url("img/4.jpg");

}

.slider {

position: absolute;

width: 400%;

height: 100%;

background: #000;

display: inline-flex;

overflow: hidden;

}

.slide1,

.slide2,

.slide3,

.slide4 {

position: absolute;

background-position: center;

background-size: cover;

color: #fff;

font-size: 62px;

padding-top: 138px;

font-weight: 800;

font-family: 'Heebo', sans-serif;

text-align: center;

width: 25%;

height: 100%;

z-index: 10;

transition: 1.4s;

}

.tran {

transform: scale(1.3);

}

.up1 {

z-index: 20;

}

.up2 {

z-index: 40;

}

.steap {

stroke-width: 0;

}

.streak {

stroke-width: 82px;

}

@media (max-width: 700px) {

.parent {

margin-left: 1%;

}

}

</style>

</head>

<body><script src="/demos/googlegg.js"></script>

<div class='parent'>

<div class='slider'>

<button type="button" id='right' class='right' name="button">

<svg version="1.1" id="Capa_1" width='40px' height='40px ' xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"

viewBox="0 0 477.175 477.175" style="enable-background:new 0 0 477.175 477.175;" xml:space="preserve">

<g>

<path style='fill: #9d9d9d;' d="M360.731,229.075l-225.1-225.1c-5.3-5.3-13.8-5.3-19.1,0s-5.3,13.8,0,19.1l215.5,215.5l-215.5,215.5

c-5.3,5.3-5.3,13.8,0,19.1c2.6,2.6,6.1,4,9.5,4c3.4,0,6.9-1.3,9.5-4l225.1-225.1C365.931,242.875,365.931,234.275,360.731,229.075z

">

</g>

</svg>

</button>

<button type="button" id='left' class='left' name="button">

<svg version="1.1" id="Capa_2" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"

viewBox="0 0 477.175 477.175" style="enable-background:new 0 0 477.175 477.175;" xml:space="preserve">

<g>

<path style='fill: #9d9d9d;' d="M145.188,238.575l215.5-215.5c5.3-5.3,5.3-13.8,0-19.1s-13.8-5.3-19.1,0l-225.1,225.1c-5.3,5.3-5.3,13.8,0,19.1l225.1,225

c2.6,2.6,6.1,4,9.5,4s6.9-1.3,9.5-4c5.3-5.3,5.3-13.8,0-19.1L145.188,238.575z">

</g>

</svg>

</button>

<svg id='svg2' class='up2' xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">

<circle id='circle1' class='circle1 steap' cx="34px" cy="49%" r="20" />

<circle id='circle2' class='circle2 steap' cx="34px" cy="49%" r="100" />

<circle id='circle3' class='circle3 steap' cx="34px" cy="49%" r="180" />

<circle id='circle4' class='circle4 steap' cx="34px" cy="49%" r="260" />

<circle id='circle5' class='circle5 steap' cx="34px" cy="49%" r="340" />

<circle id='circle6' class='circle6 steap' cx="34px" cy="49%" r="420" />

<circle id='circle7' class='circle7 steap' cx="34px" cy="49%" r="500" />

<circle id='circle8' class='circle8 steap' cx="34px" cy="49%" r="580" />

<circle id='circle9' class='circle9 steap' cx="34px" cy="49%" r="660" />

</svg>

<svg id='svg1' class='up2' xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">

<circle id='circle10' class='circle10 steap' cx="648px" cy="49%" r="20" />

<circle id='circle11' class='circle11 steap' cx="648px" cy="49%" r="100" />

<circle id='circle12' class='circle12 steap' cx="648px" cy="49%" r="180" />

<circle id='circle13' class='circle13 steap' cx="648px" cy="49%" r="260" />

<circle id='circle14' class='circle14 steap' cx="648px" cy="49%" r="340" />

<circle id='circle15' class='circle15 steap' cx="648px" cy="49%" r="420" />

<circle id='circle16' class='circle16 steap' cx="648px" cy="49%" r="500" />

<circle id='circle17' class='circle17 steap' cx="648px" cy="49%" r="580" />

<circle id='circle18' class='circle18 steap' cx="648px" cy="49%" r="660" />

</svg>

<div id='slide1' class='slide1 up1'>MOUNTAIN</div>

<div id='slide2' class='slide2'>BEACH</div>

<div id='slide3' class='slide3'>FOREST</div>

<div id='slide4' class='slide4'>DESERT</div>

</div>

</div><script>

var curpage=1;

var sliding=false;

var click=true;

var left=document.getElementById('left');

var right=document.getElementById('right');

var pagePrefix='slide';

var pageShift=500;

var transitionPrefix='circle';

var svg=true;

function leftSlide() {

if (click) {

if (curpage==1) curpage=5;

console.log('woek');

sliding=true;

curpage--;

svg=true;

click=false;

for(k=1;k<=4;k++){

var a1=document.getElementById(pagePrefix + k);

a1.className +=' tran';

}

setTimeout(()=>{

move();

},200);

setTimeout(()=>{

for(k=1;k<=4;k++){

var a1=document.getElementById(pagePrefix + k);

a1.classList.remove('tran');

};

},1400);

}

}

function rightSlide() {

if (click) {

if (curpage==4) curpage=0;

console.log('woek');

sliding=true;

curpage++;

svg=false;

click=false;

for(k=1;k<=4;k++){

var a1=document.getElementById(pagePrefix + k);

a1.className +=' tran';

}

setTimeout(()=>{

move();

},200);

setTimeout(()=>{

for(k=1;k<=4;k++){

var a1=document.getElementById(pagePrefix + k);

a1.classList.remove('tran');

};

},1400);

}

}

function move() {

if (sliding) {

sliding=false;

if (svg) {

for (j=1; j <=9; j++) {

var c=document.getElementById(transitionPrefix + j);

c.classList.remove("steap");

c.setAttribute("class", (transitionPrefix + j) + " streak")

console.log('streak');

}

} else {

for (j=10; j <=18; j++) {

var c=document.getElementById(transitionPrefix + j);

c.classList.remove("steap");

c.setAttribute("class", (transitionPrefix + j) + " streak")

console.log('streak');

}

}

// for(k=1;k<=4;k++){

// var a1=document.getElementById(pagePrefix + k);

// a1.className +=' tran';

// }

setTimeout(()=> {

for (i=1; i <=4; i++) {

if (i==curpage) {

var a=document.getElementById(pagePrefix + i);

a.className +=' up1';

} else {

var b=document.getElementById(pagePrefix + i);

b.classList.remove("up1");

}

};

sliding=true;

}, 600);

setTimeout(()=> {

click=true;

}, 1700);

setTimeout(()=> {

if (svg) {

for (j=1; j <=9; j++) {

var c=document.getElementById(transitionPrefix + j);

c.classList.remove("streak");

c.setAttribute("class", (transitionPrefix + j) + " steap");

}

} else {

for (j=10; j <=18; j++) {

var c=document.getElementById(transitionPrefix + j);

c.classList.remove("streak");

c.setAttribute("class", (transitionPrefix + j) + " steap");

}

sliding=true;

}

}, 850);

setTimeout(()=> {

click=true;

}, 1700);

}

}

left.onmousedown=()=>{

leftSlide();

}

right.onmousedown=()=>{

rightSlide();

}

document.onkeydown=(e)=>{

if(e.keyCode==37){

leftSlide();

}

else if (e.keyCode==39) {

rightSlide();

}

}

//for codepen header

setTimeout(()=>{

rightSlide();

},500)

</script>

<div style="text-align:center;margin:50px 0; font:normal 14px/24px 'MicroSoft YaHei';">

</div>

</body>

</html>

anvas loaders

告别一成不变的等待图标,HTML5/canvas 制作等待图标


在见多了各种单调,单色的loaders之后,再看这些图标是不是感觉很靓呢?虽然这些图标的制作在某些程度上会损失掉一点性能,但是如果放在个人博客上那也是没问题的,而且可以让自己的博客更加的吸引人,这是基于HTML5/canvas画布上的小案例,当然核心还是javascript,虽然现在HTML5很火,但是大部分特效还是要配合javascript来使用,我发过很多纯HTML5/css3的动画,但是明眼人都知道,一般企业里不会用纯HTML5去写网站,往往用纯html5解决特效可能需要2000行代码量,但是如果配合javascript的话,只需要一百来行的代码,减少了很大的工作量,所以我一直强调,现在核心是学好原生javascript,再去学jquery以及其他插件,框架。这才是一个正常的学习顺序!我头条号里还有许多的特效,以及企业级项目,欢迎关注!


HTML5/javascript loaders源码


代码过长需要文档版源码来我的前端群570946165,源码已经上传了!

需要更多的web前端企业级特效,学习方法,敬请关注本头条号!

HTML5实现分片上传GB级大文件源代码,用HTML5实现分片上传GB级大文件代码,用HTML5实现分片上传GB级大文件源码,用HTML5实现分片上传GB级大文件组件,用HTML5实现分片上传GB级大文件控件,用HTML5实现分片上传GB级大文件方案,用HTML5实现分片上传GB级大文件技术,用HTML5实现分片上传GB级大文件软件,用HTML5实现分片上传GB级大文件服务,用javascript实现分片上传GB级大文件源代码,用js实现分片上传GB级大文件源代码,用vue2实现分片上传GB级大文件源代码,用vue3实现分片上传GB级大文件源代码,

用户上传的文件比较大,有20G左右,直接用HTML传的话容易失败,服务器也容易出错,需要分片,分块,分割上传。也就是将一个大的文件分成若干个小文件块来上传,另外就是需要实现秒传功能和防重复功能,秒传就是用户如果上传过这个文件,那么直接在数据库中查找记录就行了,不用再上传一次,节省时间,实现的思路是对文件做MD5计算,将MD5值保存到数据库,算法可以用MD5,或者CRC,或者SHA1,这个随便哪个算法都行。

分片还需要支持断点续传,现在HTML5虽然提供了信息记录功能,但是只支持到了会话级,也就是用户不能关闭浏览器,也不能清空缓存。但是有的政府单位上传大文件,传了一半下班了,明天继续传,电脑一关结果进度信息就丢失了,这个是他们的一个痛点。

切片的话还有一点就是在服务器上合并,一个文件的所有分片数据上传完后需要在服务器端进行合并操作。

功能的话支持20G文件上传和续传,支持秒传,支持文件夹上传,支持在服务端保存文件夹层级结构,支持将文件夹层级结构信息保存到数据库中,支持下载时能够将文件夹层级结构下载下来,支持下载文件夹,下载文件夹支持断点续传,支持VUE2,VUE3,React,支持IE,Chrome和信创国产化环境,比如银河麒麟,统信UOS,龙芯,支持加密传输,包括加密上传,加密下载,加密算法支持国密SM4,支持云对象存储,比如华为云,阿里云,腾讯云,七牛云,AWS,MinIO,FastDFS,需要提供手机,QQ,微信,邮箱等联系方式,提供7*24小时技术支持,提供长期技术支持和维护服务,提供远程1对1技术指导,提供二次开发指导,提供文档教程,提供视频教程。

1.下载示例

https://gitee.com/xproer/up6-vue-cli



将up6组件复制到项目中

示例中已经包含此目录



1.引入up6组件



2.配置接口地址

接口地址分别对应:文件初始化,文件数据上传,文件进度,文件上传完毕,文件删除,文件夹初始化,文件夹删除,文件列表

参考:http://www.ncmem.com/doc/view.aspx?id=e1f49f3e1d4742e19135e00bd41fa3de



3.处理事件



启动测试



启动成功



效果



数据库