本站消息

站长简介/公众号


站长简介:高级工程师,爱好交友,无偿辅导python和前端,技术交流,面试指导,找工作指导,瞎聊都可加我微信i88811i哈,欢迎欢迎!也欢迎加入程序员交流群,专属程序员的圈子,加我微信拉你进群.欢迎关注我的微信公众号:程序员总部,程序员的家,探索程序员的人生之路!分享IT最新技术,关注行业最新动向,让你永不落伍。了解同行们的工资,生活工作中的酸甜苦辣,谋求程序员的最终出路!

 价值13000svip视频教程,前端大神匠心打造,零基础前端开发工程师视频教程全套,基础+进阶+项目实战,包含课件和源码

  出租广告位,需要合作请联系站长


+关注
已关注

分类  

暂无分类

标签  

暂无标签

日期归档  

2021-05(14)

2021-06(104)

2021-07(3)

2021-08(68)

2021-09(59)

五个拿来就能用的炫酷登录页面

发布于2022-05-07 19:12     阅读(103)     评论(0)     点赞(1)     收藏(2)


-------------写在前面-------------

上次的博文十个拿来就能用的网页炫酷特效 ,得到了大家的支持!这次我将收藏了很久的炫酷登录页面分享给大家,如果觉得有帮助可以点赞收藏支持一下,能关注一下就再好不过了o(≧▽≦*)o,之后还会分享更多干货内容,谢谢大家啦!

目录

1、炫酷星空登录

2、动态云层登录

3、深海灯光水母登录

4、炫酷蛛网登录

5、彩色气泡登录

打包文件获取


1、炫酷星空登录

html代码

  1. <!DOCTYPE HTML>
  2. <html>
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  5. <title>运营系统登录页</title>
  6. <link href="static/css/login.css" rel="stylesheet" type="text/css">
  7. <script type="text/javascript" src="static/lib/jquery/1.9.1/jquery.min.js"></script>
  8. <script src="static/js/verificationNumbers.js" tppabs="static/js/verificationNumbers.js"></script>
  9. <style>
  10. .J_codeimg{z-index:-1;position:absolute;}
  11. </style>
  12. <script>
  13. $(document).ready(function() {
  14. //验证码
  15. createCode();
  16. });
  17. </script>
  18. </head>
  19. <body>
  20. <div class="login-box" id="demo">
  21. <div class="input-content">
  22. <div class="login_tit">
  23. <div>
  24. <i class="tit-bg left"></i>
  25. Everyday · 运营系统
  26. <i class="tit-bg right"></i>
  27. </div>
  28. <p>Strive&nbsp;&nbsp;&nbsp;&nbsp;Everyday</p>
  29. </div>
  30. <p class="p user_icon">
  31. <input type="text" placeholder="账号" autocomplete="off" class="login_txtbx">
  32. </p>
  33. <p class="p pwd_icon">
  34. <input type="text" placeholder="密码" autocomplete="off" class="login_txtbx">
  35. </p>
  36. <div class="p val_icon">
  37. <div class="checkcode">
  38. <input type="text" id="J_codetext" placeholder="验证码" autocomplete="off" maxlength="4" class="login_txtbx">
  39. <canvas class="J_codeimg" id="myCanvas" onclick="createCode()" onselectstart="return false">对不起,您的浏览器不支持canvas,请下载最新版浏览器!</canvas>
  40. </div>
  41. <a class="ver_btn" onclick="createCode();" onselectstart="return false">看不清,换一张</a>
  42. </div>
  43. <div class="signup">
  44. <a class="gv" href="#" onclick="validate()">&nbsp;&nbsp;</a>
  45. <a class="gv" href="#">&nbsp;&nbsp;</a>
  46. </div>
  47. </div>
  48. <div class="canvaszz"> </div>
  49. <canvas id="canvas"></canvas>
  50. </div>
  51. <script>
  52. //宇宙特效
  53. "use strict";
  54. var canvas = document.getElementById('canvas'),
  55. ctx = canvas.getContext('2d'),
  56. w = canvas.width = window.innerWidth,
  57. h = canvas.height = window.innerHeight,
  58. hue = 217,
  59. stars = [],
  60. count = 0,
  61. maxStars = 2500;//星星数量
  62. var canvas2 = document.createElement('canvas'),
  63. ctx2 = canvas2.getContext('2d');
  64. canvas2.width = 100;
  65. canvas2.height = 100;
  66. var half = canvas2.width / 2,
  67. gradient2 = ctx2.createRadialGradient(half, half, 0, half, half, half);
  68. gradient2.addColorStop(0.025, '#CCC');
  69. gradient2.addColorStop(0.1, 'hsl(' + hue + ', 61%, 33%)');
  70. gradient2.addColorStop(0.25, 'hsl(' + hue + ', 64%, 6%)');
  71. gradient2.addColorStop(1, 'transparent');
  72. ctx2.fillStyle = gradient2;
  73. ctx2.beginPath();
  74. ctx2.arc(half, half, half, 0, Math.PI * 2);
  75. ctx2.fill();
  76. // End cache
  77. function random(min, max) {
  78. if (arguments.length < 2) {
  79. max = min;
  80. min = 0;
  81. }
  82. if (min > max) {
  83. var hold = max;
  84. max = min;
  85. min = hold;
  86. }
  87. return Math.floor(Math.random() * (max - min + 1)) + min;
  88. }
  89. function maxOrbit(x, y) {
  90. var max = Math.max(x, y),
  91. diameter = Math.round(Math.sqrt(max * max + max * max));
  92. return diameter / 2;
  93. //星星移动范围,值越大范围越小,
  94. }
  95. var Star = function() {
  96. this.orbitRadius = random(maxOrbit(w, h));
  97. this.radius = random(60, this.orbitRadius) / 18;
  98. //星星大小
  99. this.orbitX = w / 2;
  100. this.orbitY = h / 2;
  101. this.timePassed = random(0, maxStars);
  102. this.speed = random(this.orbitRadius) / 500000;
  103. //星星移动速度
  104. this.alpha = random(2, 10) / 10;
  105. count++;
  106. stars[count] = this;
  107. }
  108. Star.prototype.draw = function() {
  109. var x = Math.sin(this.timePassed) * this.orbitRadius + this.orbitX,
  110. y = Math.cos(this.timePassed) * this.orbitRadius + this.orbitY,
  111. twinkle = random(10);
  112. if (twinkle === 1 && this.alpha > 0) {
  113. this.alpha -= 0.05;
  114. } else if (twinkle === 2 && this.alpha < 1) {
  115. this.alpha += 0.05;
  116. }
  117. ctx.globalAlpha = this.alpha;
  118. ctx.drawImage(canvas2, x - this.radius / 2, y - this.radius / 2, this.radius, this.radius);
  119. this.timePassed += this.speed;
  120. }
  121. for (var i = 0; i < maxStars; i++) {
  122. new Star();
  123. }
  124. function animation() {
  125. ctx.globalCompositeOperation = 'source-over';
  126. ctx.globalAlpha = 0.5; //尾巴
  127. ctx.fillStyle = 'hsla(' + hue + ', 64%, 6%, 2)';
  128. ctx.fillRect(0, 0, w, h)
  129. ctx.globalCompositeOperation = 'lighter';
  130. for (var i = 1, l = stars.length; i < l; i++) {
  131. stars[i].draw();
  132. };
  133. window.requestAnimationFrame(animation);
  134. }
  135. animation();
  136. </script>
  137. </body>
  138. </html>

2、动态云层登录

html代码

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <meta http-equiv="pragma" content="no-cache">
  8. <meta http-equiv="cache-control" content="no-cache">
  9. <meta http-equiv="expires" content="0">
  10. <title>登录界面</title>
  11. <link href="css/default.css" rel="stylesheet" type="text/css" />
  12. <!--必要样式-->
  13. <link href="css/styles.css" rel="stylesheet" type="text/css" />
  14. <link href="css/demo.css" rel="stylesheet" type="text/css" />
  15. <link href="css/loaders.css" rel="stylesheet" type="text/css" />
  16. </head>
  17. <body>
  18. <div class='login'>
  19. <div class='login_title'>
  20. <span>管理员登录</span>
  21. </div>
  22. <div class='login_fields'>
  23. <div class='login_fields__user'>
  24. <div class='icon'>
  25. <img alt="" src='img/user_icon_copy.png'>
  26. </div>
  27. <input name="login" placeholder='用户名' maxlength="16" type='text' autocomplete="off" value="kbcxy" />
  28. <div class='validation'>
  29. <img alt="" src='img/tick.png'>
  30. </div>
  31. </div>
  32. <div class='login_fields__password'>
  33. <div class='icon'>
  34. <img alt="" src='img/lock_icon_copy.png'>
  35. </div>
  36. <input name="pwd" placeholder='密码' maxlength="16" type='text' autocomplete="off">
  37. <div class='validation'>
  38. <img alt="" src='img/tick.png'>
  39. </div>
  40. </div>
  41. <div class='login_fields__password'>
  42. <div class='icon'>
  43. <img alt="" src='img/key.png'>
  44. </div>
  45. <input name="code" placeholder='验证码' maxlength="4" type='text' name="ValidateNum" autocomplete="off">
  46. <div class='validation' style="opacity: 1; right: -5px;top: -3px;">
  47. <canvas class="J_codeimg" id="myCanvas" onclick="Code();">对不起,您的浏览器不支持canvas,请下载最新版浏览器!</canvas>
  48. </div>
  49. </div>
  50. <div class='login_fields__submit'>
  51. <input type='button' value='登录'>
  52. </div>
  53. </div>
  54. <div class='success'>
  55. </div>
  56. <div class='disclaimer'>
  57. <p>欢迎登陆后台管理系统</p>
  58. </div>
  59. </div>
  60. <div class='authent'>
  61. <div class="loader" style="height: 44px;width: 44px;margin-left: 28px;">
  62. <div class="loader-inner ball-clip-rotate-multiple">
  63. <div></div>
  64. <div></div>
  65. <div></div>
  66. </div>
  67. </div>
  68. <p>认证中...</p>
  69. </div>
  70. <div class="OverWindows"></div>
  71. <link href="layui/css/layui.css" rel="stylesheet" type="text/css" />
  72. <script type="text/javascript" src="js/jquery.min.js"></script>
  73. <script type="text/javascript" src="js/jquery-ui.min.js"></script>
  74. <script type="text/javascript" src='js/stopExecutionOnTimeout.js?t=1'></script>
  75. <script type="text/javascript" src="layui/layui.js"></script>
  76. <script type="text/javascript" src="js/Particleground.js"></script>
  77. <script type="text/javascript" src="Js/Treatment.js"></script>
  78. <script type="text/javascript" src="js/jquery.mockjax.js"></script>
  79. <script type="text/javascript">
  80. var canGetCookie = 0; //是否支持存储Cookie 0 不支持 1 支持
  81. var ajaxmockjax = 1; //是否启用虚拟Ajax的请求响 0 不启用 1 启用
  82. //默认账号密码
  83. var truelogin = "kbcxy";
  84. var truepwd = "1";
  85. var CodeVal = 0;
  86. Code();
  87. function Code() {
  88. if(canGetCookie == 1) {
  89. createCode("AdminCode");
  90. var AdminCode = getCookieValue("AdminCode");
  91. showCheck(AdminCode);
  92. } else {
  93. showCheck(createCode(""));
  94. }
  95. }
  96. function showCheck(a) {
  97. CodeVal = a;
  98. var c = document.getElementById("myCanvas");
  99. var ctx = c.getContext("2d");
  100. ctx.clearRect(0, 0, 1000, 1000);
  101. ctx.font = "80px 'Hiragino Sans GB'";
  102. ctx.fillStyle = "#E8DFE8";
  103. ctx.fillText(a, 0, 100);
  104. }
  105. $(document).keypress(function(e) {
  106. // 回车键事件
  107. if(e.which == 13) {
  108. $('input[type="button"]').click();
  109. }
  110. });
  111. //粒子背景特效
  112. // $('body').particleground({
  113. // dotColor: '#E8DFE8',
  114. // lineColor: '#133b88'
  115. // });
  116. // $('input[name="pwd"]').focus(function() {
  117. // $(this).attr('type', 'password');
  118. // });
  119. // $('input[type="text"]').focus(function() {
  120. // $(this).prev().animate({
  121. // 'opacity': '1'
  122. // }, 200);
  123. // });
  124. // $('input[type="text"],input[type="password"]').blur(function() {
  125. // $(this).prev().animate({
  126. // 'opacity': '.5'
  127. // }, 200);
  128. // });
  129. // $('input[name="login"],input[name="pwd"]').keyup(function() {
  130. // var Len = $(this).val().length;
  131. // if(!$(this).val() == '' && Len >= 5) {
  132. // $(this).next().animate({
  133. // 'opacity': '1',
  134. // 'right': '30'
  135. // }, 200);
  136. // } else {
  137. // $(this).next().animate({
  138. // 'opacity': '0',
  139. // 'right': '20'
  140. // }, 200);
  141. // }
  142. // });
  143. var open = 0;
  144. layui.use('layer', function() {
  145. //非空验证
  146. $('input[type="button"]').click(function() {
  147. var login = $('input[name="login"]').val();
  148. var pwd = $('input[name="pwd"]').val();
  149. var code = $('input[name="code"]').val();
  150. if(login == '') {
  151. ErroAlert('请输入您的账号');
  152. } else if(pwd == '') {
  153. ErroAlert('请输入密码');
  154. } else if(code == '' || code.length != 4) {
  155. ErroAlert('输入验证码');
  156. } else {
  157. //登陆
  158. var JsonData = {
  159. login: login,
  160. pwd: pwd,
  161. code: code
  162. };
  163. //$.post("url",JsonData,function(data) {
  164. console.log(111);
  165. alert("登录成功");
  166. //window.location.href = 'http://127.0.0.1:8020/jQueryLogin/index.html?__hbt=1567408106021';
  167. //});
  168. }
  169. })
  170. })
  171. //全屏
  172. var fullscreen = function() {
  173. elem = document.body;
  174. if(elem.webkitRequestFullScreen) {
  175. elem.webkitRequestFullScreen();
  176. } else if(elem.mozRequestFullScreen) {
  177. elem.mozRequestFullScreen();
  178. } else if(elem.requestFullScreen) {
  179. elem.requestFullscreen();
  180. } else {
  181. //浏览器不支持全屏API或已被禁用
  182. }
  183. }
  184. </script>
  185. <script type="text/javascript" src="img/ThreeWebGL.js"></script>
  186. <script type="text/javascript" src="img/ThreeExtras.js"></script>
  187. <script type="text/javascript" src="img/Detector.js"></script>
  188. <script type="text/javascript" src="img/RequestAnimationFrame.js"></script>
  189. <script id="vs" type="x-shader/x-vertex">
  190. varying vec2 vUv; void main() { vUv = uv; gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 ); }
  191. </script>
  192. <script id="fs" type="x-shader/x-fragment">
  193. uniform sampler2D map; uniform vec3 fogColor; uniform float fogNear; uniform float fogFar; varying vec2 vUv; void main() { float depth = gl_FragCoord.z / gl_FragCoord.w; float fogFactor = 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 ); }
  194. </script>
  195. <script type="text/javascript">
  196. if(!Detector.webgl) Detector.addGetWebGLMessage();
  197. var canvas = document.createElement('canvas');
  198. canvas.width = 32;
  199. canvas.height = window.innerHeight;
  200. var context = canvas.getContext('2d');
  201. var gradient = context.createLinearGradient(0, 0, 0, canvas.height);
  202. gradient.addColorStop(0, "#1e4877");
  203. gradient.addColorStop(0.5, "#4584b4");
  204. context.fillStyle = gradient;
  205. context.fillRect(0, 0, canvas.width, canvas.height);
  206. document.body.style.background = 'url(' + canvas.toDataURL('image/png') + ')';
  207. var container;
  208. var camera, scene, renderer, sky, mesh, geometry, material, i, h, color, colors = [],
  209. sprite, size, x, y, z;
  210. var mouseX = 0,
  211. mouseY = 0;
  212. var start_time = new Date().getTime();
  213. var windowHalfX = window.innerWidth / 2;
  214. var windowHalfY = window.innerHeight / 2;
  215. init();
  216. animate();
  217. function init() {
  218. container = document.createElement('div');
  219. document.body.appendChild(container);
  220. camera = new THREE.Camera(30, window.innerWidth / window.innerHeight, 1, 3000);
  221. camera.position.z = 6000;
  222. scene = new THREE.Scene();
  223. geometry = new THREE.Geometry();
  224. var texture = THREE.ImageUtils.loadTexture('');
  225. texture.magFilter = THREE.LinearMipMapLinearFilter;
  226. texture.minFilter = THREE.LinearMipMapLinearFilter;
  227. var fog = new THREE.Fog(0x4584b4, -100, 3000);
  228. material = new THREE.MeshShaderMaterial({
  229. uniforms: {
  230. "map": {
  231. type: "t",
  232. value: 2,
  233. texture: texture
  234. },
  235. "fogColor": {
  236. type: "c",
  237. value: fog.color
  238. },
  239. "fogNear": {
  240. type: "f",
  241. value: fog.near
  242. },
  243. "fogFar": {
  244. type: "f",
  245. value: fog.far
  246. },
  247. },
  248. vertexShader: document.getElementById('vs').textContent,
  249. fragmentShader: document.getElementById('fs').textContent,
  250. depthTest: false
  251. });
  252. var plane = new THREE.Mesh(new THREE.Plane(64, 64));
  253. for(i = 0; i < 8000; i++) {
  254. plane.position.x = Math.random() * 1000 - 500;
  255. plane.position.y = -Math.random() * Math.random() * 200 - 15;
  256. plane.position.z = i;
  257. plane.rotation.z = Math.random() * Math.PI;
  258. plane.scale.x = plane.scale.y = Math.random() * Math.random() * 1.5 + 0.5;
  259. GeometryUtils.merge(geometry, plane)
  260. }
  261. mesh = new THREE.Mesh(geometry, material);
  262. scene.addObject(mesh);
  263. mesh = new THREE.Mesh(geometry, material);
  264. mesh.position.z = -8000;
  265. scene.addObject(mesh);
  266. renderer = new THREE.WebGLRenderer({
  267. antialias: false
  268. });
  269. renderer.setSize(window.innerWidth, window.innerHeight);
  270. container.appendChild(renderer.domElement);
  271. document.addEventListener('mousemove', onDocumentMouseMove, false);
  272. window.addEventListener('resize', onWindowResize, false)
  273. }
  274. function onDocumentMouseMove(event) {
  275. mouseX = (event.clientX - windowHalfX) * 0.25;
  276. mouseY = (event.clientY - windowHalfY) * 0.15
  277. }
  278. function onWindowResize(event) {
  279. camera.aspect = window.innerWidth / window.innerHeight;
  280. camera.updateProjectionMatrix();
  281. renderer.setSize(window.innerWidth, window.innerHeight)
  282. }
  283. function animate() {
  284. requestAnimationFrame(animate);
  285. render()
  286. }
  287. function render() {
  288. position = ((new Date().getTime() - start_time) * 0.03) % 8000;
  289. camera.position.x += (mouseX - camera.target.position.x) * 0.01;
  290. camera.position.y += (-mouseY - camera.target.position.y) * 0.01;
  291. camera.position.z = -position + 8000;
  292. camera.target.position.x = camera.position.x;
  293. camera.target.position.y = camera.position.y;
  294. camera.target.position.z = camera.position.z - 1000;
  295. renderer.render(scene, camera)
  296. }
  297. </script>
  298. </body>
  299. </html>

3、深海灯光水母登录

 

html代码

  1. <!doctype html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <title>登录</title>
  6. <link rel="stylesheet" href="lib/layui/css/layui.css" media="all" />
  7. <link rel="stylesheet" href="css/login.css" />
  8. <script type="text/javascript" src="js/jquery.min.js"></script>
  9. <script type="text/javascript" src="js/jquery.pure.tooltips.js"></script>
  10. <script type="text/javascript" src="lib/layui/layui.js"></script>
  11. <style>
  12. html,body {
  13. width: 100%;
  14. height: 100%;
  15. margin: 0;
  16. padding: 0;
  17. overflow: hidden;
  18. }
  19. .container{
  20. width: 100%;
  21. height: 100%;
  22. margin: 0;
  23. padding: 0;
  24. background-color: #000000;
  25. }
  26. .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;}
  27. </style>
  28. </head>
  29. <body>
  30. <div id="jsi-jellyfish-container" class="container">
  31. <div class="beg-login-box box">
  32. <header>
  33. <h1 style="color:#FFFFFF">欢迎登录</h1>
  34. </header>
  35. <div class="beg-login-main">
  36. <form action="" class="layui-form" method="post"><input name="__RequestVerificationToken" type="hidden" value="fkfh8D89BFqTdrE2iiSdG_L781RSRtdWOH411poVUWhxzA5MzI8es07g6KPYQh9Log-xf84pIR2RIAEkOokZL3Ee3UKmX0Jc8bW8jOdhqo81" />
  37. <div class="layui-form-item">
  38. <label class="beg-login-icon">
  39. <i class="layui-icon">&#xe612;</i>
  40. </label>
  41. <input type="text" name="userName" lay-verify="userName" autocomplete="off" placeholder="请输入登录名" class="layui-input">
  42. </div>
  43. <div class="layui-form-item">
  44. <label class="beg-login-icon">
  45. <i class="layui-icon">&#xe642;</i>
  46. </label>
  47. <input id="login-password" type="password" name="password" lay-verify="password" autocomplete="off" placeholder="请输入密码" class="layui-input">
  48. </div>
  49. <div class="layui-form-item">
  50. <div class="beg-pull-left beg-login-remember" style="color:#FFFFFF;margin-top: 9%;">
  51. <label>记住帐号?</label>
  52. <input type="checkbox" name="rememberMe" lay-skin="switch" lay-text="ON|OFF" checked>
  53. </div>
  54. <div class="beg-pull-right">
  55. <button class="layui-btn layui-btn-primary" lay-submit lay-filter="login" style="margin-top: 33%;" onclick="login()">
  56. <i class="layui-icon">&#xe650;</i> 登录
  57. </button>
  58. </div>
  59. <div class="beg-clear"></div>
  60. </div>
  61. </form>
  62. </div>
  63. <footer>
  64. <!-- <p><a href="../宋加加网页/index.html"><span style="color:#06F">返回首页</span></a></p> -->
  65. </footer>
  66. </div>
  67. <script>
  68. var RENDERER = {
  69. JELLYFISH_RATE: 0.00015,
  70. DUST_RATE: 0.0005,
  71. ADJUST_DISTANCE : 100,
  72. ADJUST_OFFSET : 5,
  73. init : function(){
  74. this.setParameters();
  75. this.reconstructMethod();
  76. this.createElements();
  77. this.bindEvent();
  78. this.render();
  79. },
  80. setParameters : function(){
  81. this.$window = $(window);
  82. this.$container = $('#jsi-jellyfish-container');
  83. this.width = this.$container.width();
  84. this.height = this.$container.height();
  85. this.radius = Math.sqrt(Math.pow(this.width / 2, 2) + Math.sqrt(this.height/ 2, 2));
  86. this.distance = Math.sqrt(Math.pow(this.width, 2) + Math.sqrt(this.height, 2));
  87. this.canvas = $('<canvas />').attr({width : this.width, height : this.height}).appendTo(this.$container).get(0);
  88. this.context = this.canvas.getContext('2d');
  89. this.jellyfishes = [];
  90. this.theta = 0;
  91. this.x = 0;
  92. this.y = 0;
  93. this.destinationX = this.x;
  94. this.destinationY = this.y;
  95. this.dusts = [];
  96. },
  97. reconstructMethod : function(){
  98. this.render = this.render.bind(this);
  99. },
  100. getRandomValue : function(range){
  101. return range.min + (range.max - range.min) * Math.random();
  102. },
  103. createElements : function(){
  104. for(var i = 0, length = this.JELLYFISH_RATE * this.width * this.height; i < length; i++){
  105. this.jellyfishes.push(new JELLYFISH(this));
  106. }
  107. for(var i = 0, length = this.DUST_RATE * this.width * this.height; i < length; i++){
  108. this.dusts.push(new DUST(this));
  109. }
  110. },
  111. bindEvent : function(){
  112. this.$container.on('mousemove', this.translateCenter.bind(this, false));
  113. this.$container.on('mouseout', this.translateCenter.bind(this, true));
  114. },
  115. translateCenter : function(toAdjust, event){
  116. var offset = this.$container.offset();
  117. this.destinationX = event.clientX - offset.left + this.$window.scrollLeft();
  118. this.destinationY = event.clientY - offset.top + this.$window.scrollTop();
  119. if(!toAdjust){
  120. return;
  121. }
  122. if(this.destinationX < this.ADJUST_OFFSET){
  123. this.destinationX = 0;
  124. }else if(this.radius > this.width - this.ADJUST_OFFSET){
  125. this.destinationX = this.width;
  126. }
  127. if(this.destinationY < this.ADJUST_OFFSET){
  128. this.destinationY = 0;
  129. }else if(this.radius > this.height - this.ADJUST_OFFSET){
  130. this.destinationY = this.height;
  131. }
  132. },
  133. render : function(){
  134. requestAnimationFrame(this.render);
  135. if(this.destinationX > this.x){
  136. this.x = Math.min(this.x + this.ADJUST_DISTANCE, this.destinationX);
  137. }else{
  138. this.x = Math.max(this.x - this.ADJUST_DISTANCE, this.destinationX);
  139. }
  140. if(this.destinationY > this.y){
  141. this.y = Math.min(this.y + this.ADJUST_DISTANCE, this.destinationY);
  142. }else{
  143. this.y = Math.max(this.y - this.ADJUST_DISTANCE, this.destinationY);
  144. }
  145. var gradient = this.context.createRadialGradient(this.x, this.y, 0, this.x, this.y, this.radius);
  146. gradient.addColorStop(0, 'hsl(245, 100%, 50%)');
  147. gradient.addColorStop(0.3, 'hsl(245, 100%, 30%)');
  148. gradient.addColorStop(1, 'hsl(245, 100%, 10%)');
  149. this.context.fillStyle = gradient;
  150. this.context.fillRect(0, 0, this.width, this.height);
  151. for(var i = 0, length = this.dusts.length; i < length; i++){
  152. this.dusts[i].render(this.context, this.x, this.y);
  153. }
  154. for(var i = 0, length = this.jellyfishes.length; i < length; i++){
  155. this.jellyfishes[i].render(this.context, this.x, this.y);
  156. }
  157. }
  158. };
  159. var JELLYFISH = function(renderer){
  160. this.renderer = renderer;
  161. this.init(true);
  162. };
  163. JELLYFISH.prototype = {
  164. EXPANSION_RANGE : {min : Math.PI / 120, max : Math.PI / 30},
  165. DIRECTION_RANGE : {min : 0, max : Math.PI * 2},
  166. BASE_RANGE_X : {min : 10, max : 15},
  167. BASE_RANGE_Y : {min : 0, max : 5},
  168. BASE_RANGE_CP_X : {min : 20, max : 50},
  169. BASE_RANGE_CP_Y : {min : -40, max : -20},
  170. EXPANTION_OFFSET_RANGE : {min : 0.2, max : 0.5},
  171. EXTENSION_RATE_RANGE : {min : 0.5, max : 1.5},
  172. FEELER_LENGTH_RANGE : {min : 15, max : 30},
  173. FEELER_WIDTH_RANGE : {min : 2, max : 4},
  174. ACCELERATION_RATE : 0.2,
  175. OFFSET_TO_JUDGE : 100,
  176. FRICTION : 0.96,
  177. EXTENSION_COUNT : 100,
  178. init : function(toInit){
  179. this.radius = this.renderer.radius + this.OFFSET_TO_JUDGE * 2;
  180. if(toInit){
  181. this.x = this.renderer.getRandomValue({min : -this.OFFSET_TO_JUDGE, max : this.renderer.width + this.OFFSET_TO_JUDGE});
  182. this.y = this.renderer.getRandomValue({min : -this.OFFSET_TO_JUDGE, max : this.renderer.height + this.OFFSET_TO_JUDGE});
  183. this.direction = this.renderer.getRandomValue(this.DIRECTION_RANGE);
  184. }else{
  185. switch(condition = Math.random() * 4 | 0){
  186. case 0:
  187. this.x = -this.OFFSET_TO_JUDGE;
  188. this.y = this.renderer.getRandomValue({min : 0, max : this.renderer.height});
  189. this.direction = this.renderer.getRandomValue({min : Math.PI / 4, max : Math.PI * 3 / 4});
  190. break;
  191. case 1:
  192. this.x = this.renderer.getRandomValue({min : 0, max : this.renderer.width});
  193. this.y = -this.OFFSET_TO_JUDGE;
  194. this.direction = this.renderer.getRandomValue({min : Math.PI * 3 / 4, max : Math.PI * 5 / 4});
  195. break;
  196. case 2:
  197. this.x = this.renderer.width + this.OFFSET_TO_JUDGE;
  198. this.y = this.renderer.getRandomValue({min : 0, max : this.renderer.height});
  199. this.direction = this.renderer.getRandomValue({min : Math.PI * 5 / 4, max : Math.PI * 7 / 4});
  200. break;
  201. case 3:
  202. this.x = this.renderer.getRandomValue({min : 0, max : this.renderer.width});
  203. this.y = this.renderer.height + this.OFFSET_TO_JUDGE;
  204. this.direction = this.renderer.getRandomValue({min : Math.PI * 3 / 4, max : Math.PI * 5 / 4});
  205. }
  206. }
  207. this.expansion = 0;
  208. this.expansionDelta = this.renderer.getRandomValue(this.EXPANSION_RANGE);
  209. this.vx = 0;
  210. this.vy = 0;
  211. this.ax = Math.sin(this.direction) * this.expansionDelta * this.ACCELERATION_RATE;
  212. this.ay = -Math.cos(this.direction) * this.expansionDelta * this.ACCELERATION_RATE;
  213. this.baseX = this.renderer.getRandomValue(this.BASE_RANGE_X);
  214. this.baseY = this.renderer.getRandomValue(this.BASE_RANGE_Y);
  215. this.baseCPX = this.renderer.getRandomValue(this.BASE_RANGE_CP_X);
  216. this.baseCPY = this.renderer.getRandomValue(this.BASE_RANGE_CP_Y);
  217. this.expansionOffset = this.renderer.getRandomValue(this.EXPANTION_OFFSET_RANGE);
  218. this.feelerLength = this.renderer.getRandomValue(this.FEELER_LENGTH_RANGE);
  219. this.feelerWidth = this.renderer.getRandomValue(this.FEELER_WIDTH_RANGE);
  220. this.extensionRate = this.renderer.getRandomValue(this.EXTENSION_RATE_RANGE);
  221. this.theta = 0;
  222. },
  223. render : function(context, x, y){
  224. context.save();
  225. context.translate(this.x, this.y);
  226. context.rotate(this.direction);
  227. var opacity = 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),
  228. feelerColor = 'hsla(240, 80%, 80%, ' + 0.5 * opacity + ')',
  229. patternColor = 'hsla(240, 80%, 80%, ' + 0.8 * opacity + ')',
  230. gradient = context.createRadialGradient(0, this.baseCPY, 0, 0, this.baseCPY, this.baseY - this.baseCPY);
  231. gradient.addColorStop(0, 'hsla(245, 100%, 100%, ' + opacity + ')');
  232. gradient.addColorStop(0.5, 'hsla(245, 100%, 80%, ' + 0.6 * opacity + ')');
  233. gradient.addColorStop(1, 'hsla(245, 100%, 60%, ' + 0.4 * opacity + ')');
  234. context.fillStyle = gradient;
  235. context.strokeStyle = patternColor;
  236. context.lineWidth = 2;
  237. var baseX = this.baseX * (1 + this.expansionOffset * Math.cos(this.expansion)),
  238. theta = Math.PI / 2 - Math.abs((Math.PI - this.expansion)) / 2;
  239. context.save();
  240. this.createHead(context, baseX);
  241. context.restore();
  242. this.createMainPattern(context, baseX);
  243. this.createSubPattern(context, 0, this.baseCPY * 0.45, 0);
  244. this.createSubPattern(context, -7, this.baseCPY * 0.4, -theta);
  245. this.createSubPattern(context, 7, this.baseCPY * 0.4, theta);
  246. this.createFeeler(context, feelerColor);
  247. context.restore();
  248. if(this.expansion >= Math.PI - this.expansionDelta && this.expansion <= Math.PI){
  249. this.expansion += this.expansionDelta / this.EXTENSION_COUNT;
  250. }else{
  251. this.expansion += this.expansionDelta;
  252. }
  253. this.expansion %= Math.PI * 2;
  254. this.x += this.vx;
  255. this.y += this.vy;
  256. if(this.expansion >= 0 && this.expansion <= Math.PI){
  257. this.vx += this.ax;
  258. this.vy += this.ay;
  259. }
  260. this.vx *= this.FRICTION;
  261. this.vy *= this.FRICTION;
  262. this.judgeToReset();
  263. },
  264. createHead : function(context, baseX){
  265. context.beginPath();
  266. context.moveTo(-baseX, this.baseY);
  267. context.bezierCurveTo(-this.baseCPX, this.baseCPY, this.baseCPX, this.baseCPY, baseX, this.baseY);
  268. context.closePath();
  269. context.fill();
  270. },
  271. createMainPattern : function(context, baseX){
  272. context.beginPath();
  273. context.moveTo(-baseX * 0.6, this.baseY);
  274. context.bezierCurveTo(-this.baseCPX * 0.8, this.baseCPY * 0.5, this.baseCPX * 0.8, this.baseCPY * 0.5, baseX * 0.6, this.baseY);
  275. context.stroke();
  276. },
  277. createSubPattern : function(context, translateX, translateY, rotate){
  278. context.save();
  279. context.beginPath();
  280. context.translate(translateX, translateY);
  281. context.rotate(rotate);
  282. context.scale(1, 0.5);
  283. context.arc(0, 0, 4, 0, Math.PI * 2, false);
  284. context.stroke();
  285. context.restore();
  286. },
  287. createFeeler : function(context, feelerColor){
  288. for(var i = -3; i <= 3; i++){
  289. context.save();
  290. context.beginPath();
  291. context.strokeStyle = feelerColor;
  292. context.translate(i * 2, this.baseY);
  293. context.moveTo(0, 0);
  294. var x, cy;
  295. if(this.expansion >= 0 && this.expansion <= Math.PI){
  296. cy = (Math.PI - this.expansion) / Math.PI;
  297. x = i * this.feelerWidth * cy;
  298. }else{
  299. cy = (this.expansion - Math.PI) / Math.PI;
  300. x = i * this.feelerWidth * cy;
  301. }
  302. var rate = (cy > 0.5) ? (1 - cy) : cy;
  303. context.bezierCurveTo(x * this.extensionRate, this.feelerLength * rate, x * this.extensionRate, this.feelerLength * (1 - rate), x, this.feelerLength);
  304. context.stroke();
  305. context.restore();
  306. }
  307. },
  308. judgeToReset : function(){
  309. if(this.x < -this.OFFSET_TO_JUDGE && this.vx < 0 || this.x > this.renderer.width + this.OFFSET_TO_JUDGE && this.vx > 0
  310. || this.y < -this.OFFSET_TO_JUDGE && this.vy < 0 || this.y > this.renderer.height + this.OFFSET_TO_JUDGE && this.vy > 0){
  311. this.init(false);
  312. }
  313. }
  314. };
  315. var DUST = function(renderer){
  316. this.renderer = renderer;
  317. this.init();
  318. };
  319. DUST.prototype = {
  320. RADIUS : 5,
  321. VELOCITY : 0.1,
  322. init : function(){
  323. var phi = this.renderer.getRandomValue({min : 0, max : Math.PI * 2});
  324. this.x = this.renderer.getRandomValue({min : 0, max : this.renderer.width});
  325. this.y = this.renderer.getRandomValue({min : 0, max : this.renderer.height});
  326. this.vx = this.VELOCITY * Math.sin(phi);
  327. this.vy = this.VELOCITY * Math.cos(phi);
  328. this.opacity = 0;
  329. this.theta = 0;
  330. this.deltaTheta = this.renderer.getRandomValue({min : Math.PI / 500, max : Math.PI / 100});
  331. this.gradient = this.renderer.context.createRadialGradient(0, 0, 0, 0, 0, this.RADIUS);
  332. this.gradient.addColorStop(0, 'hsla(220, 80%, 100%, 1)');
  333. this.gradient.addColorStop(0.1, 'hsla(220, 80%, 80%, 1)');
  334. this.gradient.addColorStop(0.25, 'hsla(220, 80%, 50%, 1)');
  335. this.gradient.addColorStop(1, 'hsla(220, 80%, 30%, 0)');
  336. },
  337. render : function(context, x, y){
  338. context.save();
  339. context.translate(this.x, this.y);
  340. 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));
  341. context.fillStyle = this.gradient;
  342. context.beginPath();
  343. context.arc(0, 0, this.RADIUS, 0, Math.PI * 2, false);
  344. context.fill();
  345. context.restore();
  346. this.x += this.vx;
  347. this.y += this.vy;
  348. this.theta += this.deltaTheta;
  349. this.theta %= Math.PI * 2;
  350. if(this.x < -this.RADIUS || this.x > this.renderer.width + this.RADIUS
  351. || this.y < -this.RADIUS || this.y > this.renderer.height + this.RADIUS){
  352. this.init();
  353. }
  354. }
  355. };
  356. $(function(){
  357. RENDERER.init();
  358. layui.use(['layer', 'form'], function() {
  359. var layer = layui.layer,
  360. $ = layui.jquery,
  361. form = layui.form();
  362. //自定义验证规则
  363. form.verify({
  364. userName: function(value){
  365. if(value.trim().length < 6){
  366. return '用户名不能少于6位';
  367. }
  368. }
  369. ,password: [/(.+){6,12}$/, '密码必须6到12位']
  370. });
  371. });
  372. });
  373. </script>
  374. </body>
  375. </html>

4、炫酷蛛网登录

html代码

  1. <!DOCTYPE html>
  2. <html xmlns="http://www.w3.org/1999/xhtml" >
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <meta http-equiv="pragma" content="no-cache">
  8. <meta http-equiv="cache-control" content="no-cache">
  9. <meta http-equiv="expires" content="0">
  10. <title>视联网云接入</title>
  11. <link rel="icon" href="loginSpecial/images/favicon.ico" type="image/x-icon"/>
  12. <link rel="shortcut icon" href="loginSpecial/images/favicon.ico" type="image/x-icon"/>
  13. <link href="loginSpecial/css/default.css" rel="stylesheet" type="text/css" />
  14. <!--必要样式-->
  15. <link href="loginSpecial/css/styles.css" rel="stylesheet" type="text/css" />
  16. <link href="loginSpecial/css/demo.css" rel="stylesheet" type="text/css" />
  17. <link href="loginSpecial/css/loaders.css" rel="stylesheet" type="text/css" />
  18. <script src="loginSpecial/js/jquery-2.1.1.min.js"></script>
  19. </head>
  20. <body>
  21. <div class='login'>
  22. <!--<img class="MyLogo" src="loginSpecial/images/logo01.png" alt=" LOGO">-->
  23. <div class='login_title'>
  24. <span>管理员登录</span>
  25. </div>
  26. <div class='login_fields'>
  27. <div class='login_fields__user'>
  28. <div class='icon'>
  29. <img alt="" src='loginSpecial/img/user_icon_copy.png'>
  30. </div>
  31. <input name="login" placeholder='用户名' maxlength="16" class="username" type='text' autocomplete="off" value="admin"/>
  32. <div class='validation'>
  33. <img alt="" src='loginSpecial/img/tick.png'>
  34. </div>
  35. </div>
  36. <div class='login_fields__password'>
  37. <div class='icon'>
  38. <img alt="" src='loginSpecial/img/lock_icon_copy.png'>
  39. </div>
  40. <input name="pwd" class="passwordNumder" placeholder='密码' maxlength="16" type='text' autocomplete="off">
  41. <div class='validation'>
  42. <img alt="" src='loginSpecial/img/tick.png'>
  43. </div>
  44. </div>
  45. <div class='login_fields__password'>
  46. <div class='icon'>
  47. <img alt="" src='loginSpecial/img/key.png'>
  48. </div>
  49. <input name="code" placeholder='验证码' maxlength="4" class="ValidateNum" type='text' name="ValidateNum" autocomplete="off">
  50. <div class='validation' style="opacity: 1; right: -5px;top: -3px;">
  51. <canvas class="J_codeimg" id="myCanvas" onclick="Code();">对不起,您的浏览器不支持canvas,请下载最新版浏览器!</canvas>
  52. </div>
  53. </div>
  54. <div class='login_fields__submit'>
  55. <input type='button' value='登录'>
  56. </div>
  57. </div>
  58. <div class='success'>
  59. </div>
  60. <div class='disclaimer'>
  61. <p>欢迎登陆接入平台</p>
  62. </div>
  63. </div>
  64. <div class='authent'>
  65. <div class="loader" style="height: 60px;width: 60px;margin-left: 28px;margin-top: 40px">
  66. <div class="loader-inner ball-clip-rotate-multiple">
  67. <div></div>
  68. <div></div>
  69. <div></div>
  70. </div>
  71. </div>
  72. <p>认证中...</p>
  73. </div>
  74. <div class="OverWindows"></div>
  75. <link href="loginSpecial/layui/css/layui.css" rel="stylesheet" type="text/css" />
  76. <!--<script src="http://www.jq22.com/jquery/jquery-1.10.2.js"></script>-->
  77. <script type="text/javascript" src="loginSpecial/js/jquery-ui.min.js"></script>
  78. <script type="text/javascript" src='loginSpecial/js/stopExecutionOnTimeout.js?t=1'></script>
  79. <script src="loginSpecial/layui/layui.js" type="text/javascript"></script>
  80. <script src="loginSpecial/js/Particleground.js" type="text/javascript"></script>
  81. <script src="loginSpecial/js/Treatment.js" type="text/javascript"></script>
  82. <script src="loginSpecial/js/jquery.mockjax.js" type="text/javascript"></script>
  83. <script src="loginSpecial/js/controlLogin.js" type="text/javascript"></script>
  84. </body>
  85. </html>

5、彩色气泡登录

 

html代码

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <link rel="stylesheet" href="style.css">
  7. <title>彩色气泡登录页</title>
  8. </head>
  9. <body>
  10. <section>
  11. <!-- 背景颜色 -->
  12. <div class="color"></div>
  13. <div class="color"></div>
  14. <div class="color"></div>
  15. <div class="box">
  16. <!-- 背景圆 -->
  17. <div class="circle" style="--x:0"></div>
  18. <div class="circle" style="--x:1"></div>
  19. <div class="circle" style="--x:2"></div>
  20. <div class="circle" style="--x:3"></div>
  21. <div class="circle" style="--x:4"></div>
  22. <!-- 登录框 -->
  23. <div class="container">
  24. <div class="form">
  25. <h2>登录</h2>
  26. <form>
  27. <div class="inputBox">
  28. <input type="text" placeholder="姓名">
  29. </div>
  30. <div class="inputBox">
  31. <input type="password" placeholder="密码">
  32. </div>
  33. <div class="inputBox">
  34. <input type="submit" value="登录">
  35. </div>
  36. <p class="forget">忘记密码?<a href="#">
  37. 点击这里
  38. </a></p>
  39. <p class="forget">没有账户?<a href="#">
  40. 注册
  41. </a></p>
  42. </form>
  43. </div>
  44. </div>
  45. </div>
  46. </section>
  47. </body>
  48. </html>

打包文件获取

上次很多人私信我,文章太长了,自己粘代码容易出错,有没有打包好的文件,这次我给大家打包好啦!

私信我发送 “登录页”三个关键字, 系统自动发送您!

往期内容推荐

十个拿来就能用的网页炫酷特效_键盘奏鸣曲的博客-CSDN博客

俄罗斯方块【六种模式】【c语言】【史上最强】_键盘奏鸣曲的博客-CSDN博客


站长简介:高级工程师,爱好交友,无偿辅导python和前端,技术交流,面试指导,找工作指导,瞎聊都可加我微信i88811i哈,欢迎欢迎!也欢迎加入程序员交流群,专属程序员的圈子,加我微信拉你进群
欢迎关注我的公众号:程序员总部,关注公众号回复前端,免费领取 全套前端视频教程,关注公众号回复前端充值+你的账号,免费为您充值1000积分



所属网站分类: 技术文章 > 博客

作者:92wwhehjw

链接:http://www.qianduanheidong.com/blog/article/355885/ba87abd67624ba7582ce/

来源:前端黑洞网

任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任

1 0
收藏该文
已收藏

评论内容:(最多支持255个字符)