css实现清爽阴影的登录表单效果代码

代码语言:html

所属分类:表单美化

代码描述:css实现清爽阴影的登录表单效果代码

代码标签: css 清爽 阴影登录 表单

下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">

    <meta name="viewport" content="width=device-width, initial-scale=1">

    <style>
        @import url("css.css");
    :root {
      --base-vertical-rhythm: 1.5rem;
      --base-transition: 600ms cubic-bezier(0.22, 1, 0.19, 1);
      --button-bg-color: mediumseagreen;
      --button-border-radius: 0.15rem;
      --button-focus-bg-color: seagreen;
      --button-font-size: 1rem;
      --button-text-color: white;
      --form-font-family: 'Lato', sans-serif;
      --input-bg-color: white;
      --input-border-color: #eaeaea;
      --input-border-focus-color: #d8d8d8;
      --input-border-radius: 0.15rem;
      --input-error-color: red;
      --input-padding: 0.75rem;
      --input-placeholder-color: gray;
      --input-text-color: black;
      --input-underline-color: dodgerblue;
    }
    
    * {
      box-sizing: border-box;
    }
    
    body {
      display: flex;
      flex-direction: column;
      justify-content: center;
      text-align: left;
      font-family: 'Lato', sans-serif;
      min-height: 100vh;
      padding: 1rem;
      background-color: #fafafa;
    }
    
    h1 {
      font-size: 1.25rem;
      font-weight: 700;
      line-height: 1.2;
    }
    
    p {
      font-size: 0.85rem;
      line-height: 1.4;
    }
    
    section {
      margin: 0 auto;
      width: 100%;
      max-width: 500px;
    }
    section > * + * {
      margin-top: var(--base-vertical-rhythm);
    }
    
    .form-group {
      position: relative;
      display: flex;
      flex-direction: column-reverse;
      width: 100%;
      border-radius: var(--input-border-radius);
    }
    .form-group + * {
      margin-top: var(--base-vertical-rhythm);
    }
    
    label {
      position: absolute;
      top: var(--input-padding);
      left: calc(var(--input-padding) + 1px);
      margin-bottom: calc(var(--input-padding) * -1.5);
      font-size: 0.5rem;
      letter-spacing: 0.0025rem;
      text-transform: uppercase;
      z-index: 1;
      pointer-events: none;
      opacity: 0;
      -webkit-transform: translateY(calc(var(--input-padding) / 4));
              transform: translateY(calc(var(--input-padding) / 4));
      transition: opacity var(--base-transition), -webkit-transform var(--base-transition);
      transition: opacity var(--base-transition), transform var(--base-transition);
      transition: opacity var(--base-transition), transform var(--base-transition), -webkit-transform var(--base-transition);
    }
    .form-group:focus-within label {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
    label .error {
      color: var(--input-error-color);
      opacity: 0;
      transition: opacity var(--base-transition);
    }
    label .error:before {
      content: ' - ';
    }
    
    input[type="text"],
    input[type="email"] {
      -webkit-appearance: none;
      padding: calc(var(--input-padding) * 1.5) var(--input-padding);
      font-family: var(--form-font-family);
      font-size: 1rem;
      width: 100%;
      color: var(--input-text-color);
      background-color: var(--input-bg-color);
      outline: none;
      border: 1px solid var(--input-border-color);
      border-radius: var(--input-border-radius);
      box-shadow: rgba(0, 0, 0, 0.05) 0 0.5rem 1rem -0.25rem;
      transition: border-color var(--base-transition), box-shadow var(--base-transition), transition var(--base-transition);
    }
    input[type="text"]::-webkit-input-placeholder,
    input[type="email"]::-webkit-input-placeholder {
      color: var(--input-placeholder-color);
      transition: color var(--base-transition), -webkit-transform var(--base-transition);
      transition: color var(--base-transition), transform var(--base-transition);
      transition: color var(--base-transition), transform var(--base-transition), -webkit-transform var(--base-transition);
      transition-delay: 200ms;
    }
    input[type="text"]:-ms-input-placeholder,
    input[type="email"]:-ms-input-placeholder {
      color: var(--input-placeholder-color);
      transition: color var(--base-transition), -webkit-transform var(--base-transition);
      transition: color var(--base-transition), transform var(--base-transition);
      transition: color var(--base-transition), transform var(--base-transition), -webkit-transform var(--base-transition);
      transition-delay: 200ms;
    }
    input[type="text"]::-ms-input-placeholder,
    input[type="email"]::-ms-input-placeholder {
      color: var(--input-placeholder-color);
      transition: color var(--base-transition), -webkit-transform var(--base-transition);
      transition: color var(--base-transition), transform var(--base-transition);
      transition: color var(--base-transition), transform var(--base-transition), -webkit-transform var(--base-transition);
      transition-delay: 200ms;
    }
    input[type="text"]::placeholder,
    input[type="email"]::placeholder.........完整代码请登录后点击上方下载按钮下载查看

网友评论0