基于JS怎么实现的炫酷登录页面(JS,开发技术)

时间:2024-04-28 05:57:25 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

1、炫酷星空登录

基于JS怎么实现的炫酷登录页面

实现代码

<!DOCTYPEHTML><html><head><metahttp-equiv="Content-Type"content="text/html;charset=utf-8"><title>运营系统登录页</title><linkhref="static/css/login.css"rel="externalnofollow"rel="stylesheet"type="text/css"><scripttype="text/javascript"src="static/lib/jquery/1.9.1/jquery.min.js"></script><scriptsrc="static/js/verificationNumbers.js"tppabs="static/js/verificationNumbers.js"></script><style>.J_codeimg{z-index:-1;position:absolute;}</style><script>$(document).ready(function(){//验证码createCode();});</script></head><body><divclass="login-box"id="demo"><divclass="input-content"><divclass="login_tit"><div><iclass="tit-bgleft"></i>Everyday·运营系统<iclass="tit-bgright"></i></div><p>StriveEveryday</p></div><pclass="puser_icon"><inputtype="text"placeholder="账号"autocomplete="off"class="login_txtbx"></p><pclass="ppwd_icon"><inputtype="text"placeholder="密码"autocomplete="off"class="login_txtbx"></p> <divclass="pval_icon"><divclass="checkcode"><inputtype="text"id="J_codetext"placeholder="验证码"autocomplete="off"maxlength="4"class="login_txtbx"><canvasclass="J_codeimg"id="myCanvas"onclick="createCode()"onselectstart="returnfalse">对不起,您的浏览器不支持canvas,请下载最新版浏览器!</canvas></div><aclass="ver_btn"onclick="createCode();"onselectstart="returnfalse">看不清,换一张</a></div><divclass="signup"> <aclass="gv"href="#"rel="externalnofollow"rel="externalnofollow"rel="externalnofollow"rel="externalnofollow"onclick="validate()">登录</a><aclass="gv"href="#"rel="externalnofollow"rel="externalnofollow"rel="externalnofollow"rel="externalnofollow">清空</a></div></div><divclass="canvaszz"></div><canvasid="canvas"></canvas></div><script>//宇宙特效"usestrict";varcanvas=document.getElementById('canvas'),ctx=canvas.getContext('2d'),w=canvas.width=window.innerWidth,h=canvas.height=window.innerHeight,hue=217,stars=[],count=0,maxStars=2500;//星星数量varcanvas2=document.createElement('canvas'),ctx2=canvas2.getContext('2d');canvas2.width=100;canvas2.height=100;varhalf=canvas2.width/2,gradient2=ctx2.createRadialGradient(half,half,0,half,half,half);gradient2.addColorStop(0.025,'#CCC');gradient2.addColorStop(0.1,'hsl('+hue+',61%,33%)');gradient2.addColorStop(0.25,'hsl('+hue+',64%,6%)');gradient2.addColorStop(1,'transparent');ctx2.fillStyle=gradient2;ctx2.beginPath();ctx2.arc(half,half,half,0,Math.PI*2);ctx2.fill();//Endcachefunctionrandom(min,max){if(arguments.length<2){max=min;min=0;}if(min>max){varhold=max;max=min;min=hold;}returnMath.floor(Math.random()*(max-min+1))+min;}functionmaxOrbit(x,y){varmax=Math.max(x,y),diameter=Math.round(Math.sqrt(max*max+max*max));returndiameter/2;//星星移动范围,值越大范围越小,}varStar=function(){this.orbitRadius=random(maxOrbit(w,h));this.radius=random(60,this.orbitRadius)/18;//星星大小this.orbitX=w/2;this.orbitY=h/2;this.timePassed=random(0,maxStars);this.speed=random(this.orbitRadius)/500000;//星星移动速度this.alpha=random(2,10)/10;count++;stars[count]=this;}Star.prototype.draw=function(){varx=Math.sin(this.timePassed)*this.orbitRadius+this.orbitX,y=Math.cos(this.timePassed)*this.orbitRadius+this.orbitY,twinkle=random(10);if(twinkle===1&&this.alpha>0){this.alpha-=0.05;}elseif(twinkle===2&&this.alpha<1){this.alpha+=0.05;}ctx.globalAlpha=this.alpha;ctx.drawImage(canvas2,x-this.radius/2,y-this.radius/2,this.radius,this.radius);this.timePassed+=this.speed;}for(vari=0;i<maxStars;i++){newStar();}functionanimation(){ctx.globalCompositeOperation='source-over';ctx.globalAlpha=0.5;//尾巴ctx.fillStyle='hsla('+hue+',64%,6%,2)';ctx.fillRect(0,0,w,h)ctx.globalCompositeOperation='lighter';for(vari=1,l=stars.length;i<l;i++){stars[i].draw();};window.requestAnimationFrame(animation);}animation();</script></body></html>

2、动态云层登录

基于JS怎么实现的炫酷登录页面

实现代码

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><htmlxmlns="http://www.w3.org/1999/xhtml"> <head> <metacharset="UTF-8"> <metahttp-equiv="X-UA-Compatible"content="IE=edge,chrome=1"> <metaname="viewport"content="width=device-width,initial-scale=1.0"> <metahttp-equiv="pragma"content="no-cache"> <metahttp-equiv="cache-control"content="no-cache"> <metahttp-equiv="expires"content="0"> <title>登录界面</title> <linkhref="css/default.css"rel="externalnofollow"rel="stylesheet"type="text/css"/> <!--必要样式--> <linkhref="css/styles.css"rel="externalnofollow"rel="stylesheet"type="text/css"/> <linkhref="css/demo.css"rel="externalnofollow"rel="stylesheet"type="text/css"/> <linkhref="css/loaders.css"rel="externalnofollow"rel="stylesheet"type="text/css"/> </head> <body> <divclass='login'> <divclass='login_title'> <span>管理员登录</span> </div> <divclass='login_fields'> <divclass='login_fields__user'> <divclass='icon'> <imgalt=""src='img/user_icon_copy.png'> </div> <inputname="login"placeholder='用户名'maxlength="16"type='text'autocomplete="off"value="kbcxy"/> <divclass='validation'> <imgalt=""src='img/tick.png'> </div> </div> <divclass='login_fields__password'> <divclass='icon'> <imgalt=""src='img/lock_icon_copy.png'> </div> <inputname="pwd"placeholder='密码'maxlength="16"type='text'autocomplete="off"> <divclass='validation'> <imgalt=""src='img/tick.png'> </div> </div> <divclass='login_fields__password'> <divclass='icon'> <imgalt=""src='img/key.png'> </div> <inputname="code"placeholder='验证码'maxlength="4"type='text'name="ValidateNum"autocomplete="off"> <divclass='validation'> <canvasclass="J_codeimg"id="myCanvas"onclick="Code();">对不起,您的浏览器不支持canvas,请下载最新版浏览器!</canvas> </div> </div> <divclass='login_fields__submit'> <inputtype='button'value='登录'> </div> </div> <divclass='success'> </div> <divclass='disclaimer'> <p>欢迎登陆后台管理系统</p> </div> </div> <divclass='authent'> <divclass="loader"> <divclass="loader-innerball-clip-rotate-multiple"> <div></div> <div></div> <div></div> </div> </div> <p>认证中...</p> </div> <divclass="OverWindows"></div> <linkhref="layui/css/layui.css"rel="externalnofollow"rel="stylesheet"type="text/css"/> <scripttype="text/javascript"src="js/jquery.min.js"></script> <scripttype="text/javascript"src="js/jquery-ui.min.js"></script> <scripttype="text/javascript"src='js/stopExecutionOnTimeout.js?t=1'></script> <scripttype="text/javascript"src="layui/layui.js"></script> <scripttype="text/javascript"src="js/Particleground.js"></script> <scripttype="text/javascript"src="Js/Treatment.js"></script> <scripttype="text/javascript"src="js/jquery.mockjax.js"></script> <scripttype="text/javascript"> varcanGetCookie=0;//是否支持存储Cookie0不支持1支持 varajaxmockjax=1;//是否启用虚拟Ajax的请求响0不启用1启用 //默认账号密码 vartruelogin="kbcxy"; vartruepwd="1"; varCodeVal=0; Code(); functionCode(){ if(canGetCookie==1){ createCode("AdminCode"); varAdminCode=getCookieValue("AdminCode"); showCheck(AdminCode); }else{ showCheck(createCode("")); } } functionshowCheck(a){ CodeVal=a; varc=document.getElementById("myCanvas"); varctx=c.getContext("2d"); ctx.clearRect(0,0,1000,1000); ctx.font="80px'HiraginoSansGB'"; ctx.fillStyle="#E8DFE8"; ctx.fillText(a,0,100); } $(document).keypress(function(e){ //回车键事件 if(e.which==13){ $('input[type="button"]').click(); } }); //粒子背景特效 // $('body').particleground({ // dotColor:'#E8DFE8', // lineColor:'#133b88' // }); // $('input[name="pwd"]').focus(function(){ // $(this).attr('type','password'); // }); // $('input[type="text"]').focus(function(){ // $(this).prev().animate({ // 'opacity':'1' // },200); // }); // $('input[type="text"],input[type="password"]').blur(function(){ // $(this).prev().animate({ // 'opacity':'.5' // },200); // }); // $('input[name="login"],input[name="pwd"]').keyup(function(){ // varLen=$(this).val().length; // if(!$(this).val()==''&&Len>=5){ // $(this).next().animate({ // 'opacity':'1', // 'right':'30' // },200); // }else{ // $(this).next().animate({ // 'opacity':'0', // 'right':'20' // },200); // } // }); varopen=0; layui.use('layer',function(){ //非空验证 $('input[type="button"]').click(function(){ varlogin=$('input[name="login"]').val(); varpwd=$('input[name="pwd"]').val(); varcode=$('input[name="code"]').val(); if(login==''){ ErroAlert('请输入您的账号'); }elseif(pwd==''){ ErroAlert('请输入密码'); }elseif(code==''||code.length!=4){ ErroAlert('输入验证码'); }else{ //登陆 varJsonData={ login:login, pwd:pwd, code:code }; //$.post("url",JsonData,function(data){ console.log(111); alert("登录成功"); //window.location.href='http://127.0.0.1:8020/jQueryLogin/index.html?__hbt=1567408106021'; //}); } }) }) //全屏 varfullscreen=function(){ elem=document.body; if(elem.webkitRequestFullScreen){ elem.webkitRequestFullScreen(); }elseif(elem.mozRequestFullScreen){ elem.mozRequestFullScreen(); }elseif(elem.requestFullScreen){ elem.requestFullscreen(); }else{ //浏览器不支持全屏API或已被禁用 } } </script> <scripttype="text/javascript"src="img/ThreeWebGL.js"></script> <scripttype="text/javascript"src="img/ThreeExtras.js"></script> <scripttype="text/javascript"src="img/Detector.js"></script> <scripttype="text/javascript"src="img/RequestAnimationFrame.js"></script> <scriptid="vs"type="x-shader/x-vertex"> varyingvec2vUv;voidmain(){vUv=uv;gl_Position=projectionMatrix*modelViewMatrix*vec4(position,1.0);} </script> <scriptid="fs"type="x-shader/x-fragment"> uniformsampler2Dmap;uniformvec3fogColor;uniformfloatfogNear;uniformfloatfogFar;varyingvec2vUv;voidmain(){floatdepth=gl_FragCoord.z/gl_FragCoord.w;floatfogFactor=smoothstep(fogNear,fogFar,depth);gl_FragColor=texture2D(map,vUv);gl_FragColor.w*=pow(gl_FragCoord.z,20.0);gl_FragColor=mix(gl_FragColor,vec4(fogColor,gl_FragColor.w),fogFactor);} </script> <scripttype="text/javascript"> if(!Detector.webgl)Detector.addGetWebGLMessage(); varcanvas=document.createElement('canvas'); canvas.width=32; canvas.height=window.innerHeight; varcontext=canvas.getContext('2d'); vargradient=context.createLinearGradient(0,0,0,canvas.height); gradient.addColorStop(0,"#1e4877"); gradient.addColorStop(0.5,"#4584b4"); context.fillStyle=gradient; context.fillRect(0,0,canvas.width,canvas.height); document.body.style.background='url('+canvas.toDataURL('image/png')+')'; varcontainer; varcamera,scene,renderer,sky,mesh,geometry,material,i,h,color,colors=[], sprite,size,x,y,z; varmouseX=0, mouseY=0; varstart_time=newDate().getTime(); varwindowHalfX=window.innerWidth/2; varwindowHalfY=window.innerHeight/2; init(); animate(); functioninit(){ container=document.createElement('div'); document.body.appendChild(container); camera=newTHREE.Camera(30,window.innerWidth/window.innerHeight,1,3000); camera.position.z=6000; scene=newTHREE.Scene(); geometry=newTHREE.Geometry(); vartexture=THREE.ImageUtils.loadTexture(''); texture.magFilter=THREE.LinearMipMapLinearFilter; texture.minFilter=THREE.LinearMipMapLinearFilter; varfog=newTHREE.Fog(0x4584b4,-100,3000); material=newTHREE.MeshShaderMaterial({ uniforms:{ "map":{ type:"t", value:2, texture:texture }, "fogColor":{ type:"c", value:fog.color }, "fogNear":{ type:"f", value:fog.near }, "fogFar":{ type:"f", value:fog.far }, }, vertexShader:document.getElementById('vs').textContent, fragmentShader:document.getElementById('fs').textContent, depthTest:false }); varplane=newTHREE.Mesh(newTHREE.Plane(64,64)); for(i=0;i<8000;i++){ plane.position.x=Math.random()*1000-500; plane.position.y=-Math.random()*Math.random()*200-15; plane.position.z=i; plane.rotation.z=Math.random()*Math.PI; plane.scale.x=plane.scale.y=Math.random()*Math.random()*1.5+0.5; GeometryUtils.merge(geometry,plane) } mesh=newTHREE.Mesh(geometry,material); scene.addObject(mesh); mesh=newTHREE.Mesh(geometry,material); mesh.position.z=-8000; scene.addObject(mesh); renderer=newTHREE.WebGLRenderer({ antialias:false }); renderer.setSize(window.innerWidth,window.innerHeight); container.appendChild(renderer.domElement); document.addEventListener('mousemove',onDocumentMouseMove,false); window.addEventListener('resize',onWindowResize,false) } functiononDocumentMouseMove(event){ mouseX=(event.clientX-windowHalfX)*0.25; mouseY=(event.clientY-windowHalfY)*0.15 } functiononWindowResize(event){ camera.aspect=window.innerWidth/window.innerHeight; camera.updateProjectionMatrix(); renderer.setSize(window.innerWidth,window.innerHeight) } functionanimate(){ requestAnimationFrame(animate); render() } functionrender(){ position=((newDate().getTime()-start_time)*0.03)%8000; camera.position.x+=(mouseX-camera.target.position.x)*0.01; camera.position.y+=(-mouseY-camera.target.position.y)*0.01; camera.position.z=-position+8000; camera.target.position.x=camera.position.x; camera.target.position.y=camera.position.y; camera.target.position.z=camera.position.z-1000; renderer.render(scene,camera) } </script> </body></html>

3、深海灯光水母登录

基于JS怎么实现的炫酷登录页面

实现代码

<!doctypehtml><html><head><metacharset="utf-8"><title>登录</title><linkrel="stylesheet"href="lib/layui/css/layui.css"rel="externalnofollow"media="all"/><linkrel="stylesheet"href="css/login.css"rel="externalnofollow"/><scripttype="text/javascript"src="js/jquery.min.js"></script><scripttype="text/javascript"src="js/jquery.pure.tooltips.js"></script><scripttype="text/javascript"src="lib/layui/layui.js"></script><style>html,body{width:100%;height:100%;margin:0;padding:0;overflow:hidden;}.container{width:100%;height:100%;margin:0;padding:0;background-color:#000000;}.box{width:450px;height:295px;background:#000000;position:absolute;top:50%;left:50%;margin-left:-14%;margin-top:-10%;z-index:3;opacity:0.6;}</style></head><body><divid="jsi-jellyfish-container"class="container"><divclass="beg-login-boxbox"> <header> <h2>欢迎登录</h2> </header> <divclass="beg-login-main"> <formaction=""class="layui-form"method="post"><inputname="__RequestVerificationToken"type="hidden"value="fkfh8D89BFqTdrE2iiSdG_L781RSRtdWOH411poVUWhxzA5MzI8es07g6KPYQh9Log-xf84pIR2RIAEkOokZL3Ee3UKmX0Jc8bW8jOdhqo81"/> <divclass="layui-form-item"> <labelclass="beg-login-icon"> <iclass="layui-icon">&#xe612;</i> </label> <inputtype="text"name="userName"lay-verify="userName"autocomplete="off"placeholder="请输入登录名"class="layui-input"> </div> <divclass="layui-form-item"> <labelclass="beg-login-icon"> <iclass="layui-icon">&#xe642;</i> </label> <inputid="login-password"type="password"name="password"lay-verify="password"autocomplete="off"placeholder="请输入密码"class="layui-input"> </div> <divclass="layui-form-item"> <divclass="beg-pull-leftbeg-login-remember"> <label>记住帐号?</label> <inputtype="checkbox"name="rememberMe"lay-skin="switch"lay-text="ON|OFF"checked> </div> <divclass="beg-pull-right"> <buttonclass="layui-btnlayui-btn-primary"lay-submitlay-filter="login"onclick="login()"> <iclass="layui-icon">&#xe650;</i>登录 </button> </div> <divclass="beg-clear"></div> </div> </form> </div> <footer> <!--<p><ahref="../宋加加网页/index.html"rel="externalnofollow"><span>返回首页</span></a></p>--> </footer></div><script>varRENDERER={ JELLYFISH_RATE:0.00015, DUST_RATE:0.0005, ADJUST_DISTANCE:100, ADJUST_OFFSET:5, init:function(){ this.setParameters(); this.reconstructMethod(); this.createElements(); this.bindEvent(); this.render(); }, setParameters:function(){ this.$window=$(window); this.$container=$('#jsi-jellyfish-container'); this.width=this.$container.width(); this.height=this.$container.height(); this.radius=Math.sqrt(Math.pow(this.width/2,2)+Math.sqrt(this.height/2,2)); this.distance=Math.sqrt(Math.pow(this.width,2)+Math.sqrt(this.height,2)); this.canvas=$('<canvas/>').attr({width:this.width,height:this.height}).appendTo(this.$container).get(0); this.context=this.canvas.getContext('2d'); this.jellyfishes=[]; this.theta=0; this.x=0; this.y=0; this.destinationX=this.x; this.destinationY=this.y; this.dusts=[]; }, reconstructMethod:function(){ this.render=this.render.bind(this); }, getRandomValue:function(range){ returnrange.min+(range.max-range.min)*Math.random(); }, createElements:function(){ for(vari=0,length=this.JELLYFISH_RATE*this.width*this.height;i<length;i++){ this.jellyfishes.push(newJELLYFISH(this)); } for(vari=0,length=this.DUST_RATE*this.width*this.height;i<length;i++){ this.dusts.push(newDUST(this)); } }, bindEvent:function(){ this.$container.on('mousemove',this.translateCenter.bind(this,false)); this.$container.on('mouseout',this.translateCenter.bind(this,true)); }, translateCenter:function(toAdjust,event){ varoffset=this.$container.offset(); this.destinationX=event.clientX-offset.left+this.$window.scrollLeft(); this.destinationY=event.clientY-offset.top+this.$window.scrollTop(); if(!toAdjust){ return; } if(this.destinationX<this.ADJUST_OFFSET){ this.destinationX=0; }elseif(this.radius>this.width-this.ADJUST_OFFSET){ this.destinationX=this.width; } if(this.destinationY<this.ADJUST_OFFSET){ this.destinationY=0; }elseif(this.radius>this.height-this.ADJUST_OFFSET){ this.destinationY=this.height; } }, render:function(){ requestAnimationFrame(this.render); if(this.destinationX>this.x){ this.x=Math.min(this.x+this.ADJUST_DISTANCE,this.destinationX); }else{ this.x=Math.max(this.x-this.ADJUST_DISTANCE,this.destinationX); } if(this.destinationY>this.y){ this.y=Math.min(this.y+this.ADJUST_DISTANCE,this.destinationY); }else{ this.y=Math.max(this.y-this.ADJUST_DISTANCE,this.destinationY); } vargradient=this.context.createRadialGradient(this.x,this.y,0,this.x,this.y,this.radius); gradient.addColorStop(0,'hsl(245,100%,50%)'); gradient.addColorStop(0.3,'hsl(245,100%,30%)'); gradient.addColorStop(1,'hsl(245,100%,10%)'); this.context.fillStyle=gradient; this.context.fillRect(0,0,this.width,this.height); for(vari=0,length=this.dusts.length;i<length;i++){ this.dusts[i].render(this.context,this.x,this.y); } for(vari=0,length=this.jellyfishes.length;i<length;i++){ this.jellyfishes[i].render(this.context,this.x,this.y); } }};varJELLYFISH=function(renderer){ this.renderer=renderer; this.init(true);};JELLYFISH.prototype={ EXPANSION_RANGE:{min:Math.PI/120,max:Math.PI/30}, DIRECTION_RANGE:{min:0,max:Math.PI*2}, BASE_RANGE_X:{min:10,max:15}, BASE_RANGE_Y:{min:0,max:5}, BASE_RANGE_CP_X:{min:20,max:50}, BASE_RANGE_CP_Y:{min:-40,max:-20}, EXPANTION_OFFSET_RANGE:{min:0.2,max:0.5}, EXTENSION_RATE_RANGE:{min:0.5,max:1.5}, FEELER_LENGTH_RANGE:{min:15,max:30}, FEELER_WIDTH_RANGE:{min:2,max:4}, ACCELERATION_RATE:0.2, OFFSET_TO_JUDGE:100, FRICTION:0.96, EXTENSION_COUNT:100, init:function(toInit){ this.radius=this.renderer.radius+this.OFFSET_TO_JUDGE*2; if(toInit){ this.x=this.renderer.getRandomValue({min:-this.OFFSET_TO_JUDGE,max:this.renderer.width+this.OFFSET_TO_JUDGE}); this.y=this.renderer.getRandomValue({min:-this.OFFSET_TO_JUDGE,max:this.renderer.height+this.OFFSET_TO_JUDGE}); this.direction=this.renderer.getRandomValue(this.DIRECTION_RANGE); }else{ switch(condition=Math.random()*4|0){ case0: this.x=-this.OFFSET_TO_JUDGE; this.y=this.renderer.getRandomValue({min:0,max:this.renderer.height}); this.direction=this.renderer.getRandomValue({min:Math.PI/4,max:Math.PI*3/4}); break; case1: this.x=this.renderer.getRandomValue({min:0,max:this.renderer.width}); this.y=-this.OFFSET_TO_JUDGE; this.direction=this.renderer.getRandomValue({min:Math.PI*3/4,max:Math.PI*5/4}); break; case2: this.x=this.renderer.width+this.OFFSET_TO_JUDGE; this.y=this.renderer.getRandomValue({min:0,max:this.renderer.height}); this.direction=this.renderer.getRandomValue({min:Math.PI*5/4,max:Math.PI*7/4}); break; case3: this.x=this.renderer.getRandomValue({min:0,max:this.renderer.width}); this.y=this.renderer.height+this.OFFSET_TO_JUDGE; this.direction=this.renderer.getRandomValue({min:Math.PI*3/4,max:Math.PI*5/4}); } } this.expansion=0; this.expansionDelta=this.renderer.getRandomValue(this.EXPANSION_RANGE); this.vx=0; this.vy=0; this.ax=Math.sin(this.direction)*this.expansionDelta*this.ACCELERATION_RATE; this.ay=-Math.cos(this.direction)*this.expansionDelta*this.ACCELERATION_RATE; this.baseX=this.renderer.getRandomValue(this.BASE_RANGE_X); this.baseY=this.renderer.getRandomValue(this.BASE_RANGE_Y); this.baseCPX=this.renderer.getRandomValue(this.BASE_RANGE_CP_X); this.baseCPY=this.renderer.getRandomValue(this.BASE_RANGE_CP_Y); this.expansionOffset=this.renderer.getRandomValue(this.EXPANTION_OFFSET_RANGE); this.feelerLength=this.renderer.getRandomValue(this.FEELER_LENGTH_RANGE); this.feelerWidth=this.renderer.getRandomValue(this.FEELER_WIDTH_RANGE); this.extensionRate=this.renderer.getRandomValue(this.EXTENSION_RATE_RANGE); this.theta=0; }, render:function(context,x,y){ context.save(); context.translate(this.x,this.y); context.rotate(this.direction); varopacity=0.1+0.9*Math.pow(1-Math.min(1,Math.sqrt(Math.pow(this.x-x,2)+Math.pow(this.y-y,2))/this.renderer.distance),2), feelerColor='hsla(240,80%,80%,'+0.5*opacity+')', patternColor='hsla(240,80%,80%,'+0.8*opacity+')', gradient=context.createRadialGradient(0,this.baseCPY,0,0,this.baseCPY,this.baseY-this.baseCPY); gradient.addColorStop(0,'hsla(245,100%,100%,'+opacity+')'); gradient.addColorStop(0.5,'hsla(245,100%,80%,'+0.6*opacity+')'); gradient.addColorStop(1,'hsla(245,100%,60%,'+0.4*opacity+')'); context.fillStyle=gradient; context.strokeStyle=patternColor; context.lineWidth=2; varbaseX=this.baseX*(1+this.expansionOffset*Math.cos(this.expansion)), theta=Math.PI/2-Math.abs((Math.PI-this.expansion))/2; context.save(); this.createHead(context,baseX); context.restore(); this.createMainPattern(context,baseX); this.createSubPattern(context,0,this.baseCPY*0.45,0); this.createSubPattern(context,-7,this.baseCPY*0.4,-theta); this.createSubPattern(context,7,this.baseCPY*0.4,theta); this.createFeeler(context,feelerColor); context.restore(); if(this.expansion>=Math.PI-this.expansionDelta&&this.expansion<=Math.PI){ this.expansion+=this.expansionDelta/this.EXTENSION_COUNT; }else{ this.expansion+=this.expansionDelta; } this.expansion%=Math.PI*2; this.x+=this.vx; this.y+=this.vy; if(this.expansion>=0&&this.expansion<=Math.PI){ this.vx+=this.ax; this.vy+=this.ay; } this.vx*=this.FRICTION; this.vy*=this.FRICTION; this.judgeToReset(); }, createHead:function(context,baseX){ context.beginPath(); context.moveTo(-baseX,this.baseY); context.bezierCurveTo(-this.baseCPX,this.baseCPY,this.baseCPX,this.baseCPY,baseX,this.baseY); context.closePath(); context.fill(); }, createMainPattern:function(context,baseX){ context.beginPath(); context.moveTo(-baseX*0.6,this.baseY); context.bezierCurveTo(-this.baseCPX*0.8,this.baseCPY*0.5,this.baseCPX*0.8,this.baseCPY*0.5,baseX*0.6,this.baseY); context.stroke(); }, createSubPattern:function(context,translateX,translateY,rotate){ context.save(); context.beginPath(); context.translate(translateX,translateY); context.rotate(rotate); context.scale(1,0.5); context.arc(0,0,4,0,Math.PI*2,false); context.stroke(); context.restore(); }, createFeeler:function(context,feelerColor){ for(vari=-3;i<=3;i++){ context.save(); context.beginPath(); context.strokeStyle=feelerColor; context.translate(i*2,this.baseY); context.moveTo(0,0); varx,cy; if(this.expansion>=0&&this.expansion<=Math.PI){ cy=(Math.PI-this.expansion)/Math.PI; x=i*this.feelerWidth*cy; }else{ cy=(this.expansion-Math.PI)/Math.PI; x=i*this.feelerWidth*cy; } varrate=(cy>0.5)?(1-cy):cy; context.bezierCurveTo(x*this.extensionRate,this.feelerLength*rate,x*this.extensionRate,this.feelerLength*(1-rate),x,this.feelerLength); context.stroke(); context.restore(); } }, judgeToReset:function(){ if(this.x<-this.OFFSET_TO_JUDGE&&this.vx<0||this.x>this.renderer.width+this.OFFSET_TO_JUDGE&&this.vx>0 ||this.y<-this.OFFSET_TO_JUDGE&&this.vy<0||this.y>this.renderer.height+this.OFFSET_TO_JUDGE&&this.vy>0){ this.init(false); } }};varDUST=function(renderer){ this.renderer=renderer; this.init();};DUST.prototype={ RADIUS:5, VELOCITY:0.1, init:function(){ varphi=this.renderer.getRandomValue({min:0,max:Math.PI*2}); this.x=this.renderer.getRandomValue({min:0,max:this.renderer.width}); this.y=this.renderer.getRandomValue({min:0,max:this.renderer.height}); this.vx=this.VELOCITY*Math.sin(phi); this.vy=this.VELOCITY*Math.cos(phi); this.opacity=0; this.theta=0; this.deltaTheta=this.renderer.getRandomValue({min:Math.PI/500,max:Math.PI/100}); this.gradient=this.renderer.context.createRadialGradient(0,0,0,0,0,this.RADIUS); this.gradient.addColorStop(0,'hsla(220,80%,100%,1)'); this.gradient.addColorStop(0.1,'hsla(220,80%,80%,1)'); this.gradient.addColorStop(0.25,'hsla(220,80%,50%,1)'); this.gradient.addColorStop(1,'hsla(220,80%,30%,0)'); }, render:function(context,x,y){ context.save(); context.translate(this.x,this.y); context.globalAlpha=Math.abs(Math.sin(this.theta))*(0.2+0.8*Math.pow(Math.min(1,Math.sqrt(Math.pow(this.x-x,2)+Math.pow(this.y-y,2))/this.renderer.distance),2)); context.fillStyle=this.gradient; context.beginPath(); context.arc(0,0,this.RADIUS,0,Math.PI*2,false); context.fill(); context.restore(); this.x+=this.vx; this.y+=this.vy; this.theta+=this.deltaTheta; this.theta%=Math.PI*2; if(this.x<-this.RADIUS||this.x>this.renderer.width+this.RADIUS ||this.y<-this.RADIUS||this.y>this.renderer.height+this.RADIUS){ this.init(); } }};$(function(){ RENDERER.init(); layui.use(['layer','form'],function(){ varlayer=layui.layer, $=layui.jquery, form=layui.form(); //自定义验证规则 form.verify({ userName:function(value){ if(value.trim().length<6){ return'用户名不能少于6位'; } } ,password:[/(.+){6,12}$/,'密码必须6到12位'] }); });});</script></body></html>

4、炫酷蛛网登录

基于JS怎么实现的炫酷登录页面

实现代码

<!DOCTYPEhtml><htmlxmlns="http://www.w3.org/1999/xhtml"><head><metacharset="UTF-8"><metahttp-equiv="X-UA-Compatible"content="IE=edge,chrome=1"><metaname="viewport"content="width=device-width,initial-scale=1.0"><metahttp-equiv="pragma"content="no-cache"><metahttp-equiv="cache-control"content="no-cache"><metahttp-equiv="expires"content="0"><title>视联网云接入</title><linkrel="icon"href="loginSpecial/images/favicon.ico"rel="externalnofollow"rel="externalnofollow"type="image/x-icon"/><linkrel="shortcuticon"href="loginSpecial/images/favicon.ico"rel="externalnofollow"rel="externalnofollow"type="image/x-icon"/><linkhref="loginSpecial/css/default.css"rel="externalnofollow"rel="stylesheet"type="text/css"/><!--必要样式--><linkhref="loginSpecial/css/styles.css"rel="externalnofollow"rel="stylesheet"type="text/css"/><linkhref="loginSpecial/css/demo.css"rel="externalnofollow"rel="stylesheet"type="text/css"/><linkhref="loginSpecial/css/loaders.css"rel="externalnofollow"rel="stylesheet"type="text/css"/><scriptsrc="loginSpecial/js/jquery-2.1.1.min.js"></script></head><body><divclass='login'><!--<imgclass="MyLogo"src="loginSpecial/images/logo01.png"alt="LOGO">--><divclass='login_title'><span>管理员登录</span></div><divclass='login_fields'><divclass='login_fields__user'><divclass='icon'><imgalt=""src='loginSpecial/img/user_icon_copy.png'></div><inputname="login"placeholder='用户名'maxlength="16"class="username"type='text'autocomplete="off"value="admin"/><divclass='validation'><imgalt=""src='loginSpecial/img/tick.png'></div></div><divclass='login_fields__password'><divclass='icon'><imgalt=""src='loginSpecial/img/lock_icon_copy.png'></div><inputname="pwd"class="passwordNumder"placeholder='密码'maxlength="16"type='text'autocomplete="off"><divclass='validation'><imgalt=""src='loginSpecial/img/tick.png'></div></div><divclass='login_fields__password'><divclass='icon'><imgalt=""src='loginSpecial/img/key.png'></div><inputname="code"placeholder='验证码'maxlength="4"class="ValidateNum"type='text'name="ValidateNum"autocomplete="off"><divclass='validation'><canvasclass="J_codeimg"id="myCanvas"onclick="Code();">对不起,您的浏览器不支持canvas,请下载最新版浏览器!</canvas></div></div><divclass='login_fields__submit'><inputtype='button'value='登录'></div></div><divclass='success'></div><divclass='disclaimer'><p>欢迎登陆接入平台</p></div></div><divclass='authent'><divclass="loader"><divclass="loader-innerball-clip-rotate-multiple"><div></div><div></div><div></div></div></div><p>认证中...</p></div><divclass="OverWindows"></div><linkhref="loginSpecial/layui/css/layui.css"rel="externalnofollow"rel="stylesheet"type="text/css"/><!--<scriptsrc="http://www.jq22.com/jquery/jquery-1.10.2.js"></script>--><scripttype="text/javascript"src="loginSpecial/js/jquery-ui.min.js"></script><scripttype="text/javascript"src='loginSpecial/js/stopExecutionOnTimeout.js?t=1'></script><scriptsrc="loginSpecial/layui/layui.js"type="text/javascript"></script><scriptsrc="loginSpecial/js/Particleground.js"type="text/javascript"></script><scriptsrc="loginSpecial/js/Treatment.js"type="text/javascript"></script><scriptsrc="loginSpecial/js/jquery.mockjax.js"type="text/javascript"></script><scriptsrc="loginSpecial/js/controlLogin.js"type="text/javascript"></script></body></html>

5、彩色气泡登录

基于JS怎么实现的炫酷登录页面

实现代码

<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><metaname="viewport"content="width=device-width,initial-scale=1.0"><linkrel="stylesheet"href="style.css"rel="externalnofollow"><title>彩色气泡登录页</title></head><body><section><!--背景颜色--><divclass="color"></div><divclass="color"></div><divclass="color"></div><divclass="box"><!--背景圆--><divclass="circle"></div><divclass="circle"></div><divclass="circle"></div><divclass="circle"></div><divclass="circle"></div><!--登录框--><divclass="container"><divclass="form"><h3>登录</h3><form><divclass="inputBox"><inputtype="text"placeholder="姓名"></div><divclass="inputBox"><inputtype="password"placeholder="密码"></div><divclass="inputBox"><inputtype="submit"value="登录"></div><pclass="forget">忘记密码?<ahref="#"rel="externalnofollow"rel="externalnofollow"rel="externalnofollow"rel="externalnofollow">点击这里</a></p><pclass="forget">没有账户?<ahref="#"rel="externalnofollow"rel="externalnofollow"rel="externalnofollow"rel="externalnofollow">注册</a></p></form></div></div></div></section></body></html>
 </div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
本文:基于JS怎么实现的炫酷登录页面的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:css3中单数li怎么写法下一篇:

8 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18