純CSS實現表單驗證

陳大魚頭發表於2019-01-19

關於表單驗證

在我們的日常業務中,表單驗證是個很常見設計需求,像一些登入註冊框,問卷調查也都需要用到表單驗證。

一般我們的實現思路都是JS監聽input框的輸入內容,判斷使用者輸入內容,從而以此來決定下一步的操作。

例如這樣:(以下例子來自優秀的開源UI庫,element

<el-form :model="numberValidateForm" ref="numberValidateForm" label-width="100px" class="demo-ruleForm">
  <el-form-item
    label="年齡"
    prop="age"
    :rules="[
      { required: true, message: '年齡不能為空'},
      { type: 'number', message: '年齡必須為數字值'}
    ]"
  >
    <el-input type="age" v-model.number="numberValidateForm.age" autocomplete="off"></el-input>
  </el-form-item>
  <el-form-item>
    <el-button type="primary" @click="submitForm('numberValidateForm')">提交</el-button>
    <el-button @click="resetForm('numberValidateForm')">重置</el-button>
  </el-form-item>
</el-form>
<script>
  export default {
    data() {
      return {
        numberValidateForm: {
          age: ''
        }
      };
    },
    methods: {
      submitForm(formName) {
        this.$refs[formName].validate((valid) => {
          if (valid) {
            alert('submit!');
          } else {
            console.log('error submit!!');
            return false;
          }
        });
      },
      resetForm(formName) {
        this.$refs[formName].resetFields();
      }
    }
  }
</script>
複製程式碼

以上就是我們常規的表達驗證了,基本就都是用JS來完成的,那麼我們能不能用CSS來實現呢?答案是可以的。這裡先上DEMO

CSS實現表單驗證

上面的表單驗證就完全是由CSS來實現的,核心屬性就是CSS Level 4Validity。思路就是利用:valid:invalid可以對<input>value進行判斷的特性。

這裡是全部程式碼

/*
 * css
 */
 :root {
 	--error-color: red;
 }
 .form > input {
 	margin-bottom: 10px;
 }
 .form > .f-tips {
 	color: var(--error-color);
 	display: none;
 }
 input[type="text"]:invalid ~ input[type="submit"],
 input[type="password"]:invalid ~ input[type="submit"] {
 	display: none;
 }
 input[required]:invalid + span {
 	display: inline;
 }
 
 /*
  * html
  */
<form class="form" id="form" method="get" action="/api/form">
    賬號:
    <input data-title="賬號" pattern="\w{6,10}" name="account" type="text" required />
    <span class="f-tips">請輸入正確的賬號</span>
    <br />
    密碼:
    <input data-title="密碼" pattern="\w{6,10}" name="password" type="password" required />
    <span class="f-tips">請輸入正確的密碼</span>
    <br />
    <input name="button" type="submit" value="提交" />
</form>
複製程式碼

效果截圖

invalid

valid

使用到的知識點

1. HTML5<input>的新屬性:pattern

MDN的解釋:

檢查控制元件值的正規表示式.。pattern必須匹配整個值,而不僅僅是某些子集.。使用title屬性來描述幫助使用者的模式.。當型別屬性的值為text, search, tel, url 或 email時,此屬性適用,否則將被忽略。(相容ie10+)

備註:

  1. 如果pattern裡的驗證規則不合法,例如多了長度校驗內多了空格,也是會在控制檯報錯的,詳情如下:

error-pattern

<input data-title="賬號" pattern="/[\w]{6, 10}/" name="account" type="text" required />
複製程式碼
  1. CSSJS裡的驗證規則不一樣,以下寫法是會無效的,核心校驗規則需要用[]包起來(目前從測試的幾個例子是這樣,具體詳情還需要翻查資料,如果有大佬知道更具體的資訊,請告知,謝謝!)
<input data-title="賬號" pattern="/\w{6,10}/" name="account" type="text" required />
複製程式碼

2. CSS Level 4 選擇器的新屬性:invalid

詳細介紹請看我的博文[譯]19個CSS level 4 選擇器



如果你也喜歡`CSS`,喜歡探討技術,或者對本文,本系列有任何的意見或建議,魚頭非常希望你能加入一個有趣的微信群 — “進擊的CSS”。你可以掃描下方二維碼,新增魚頭微信,新增時註明 “加群”,如果你覺得我的文章有趣,歡迎關注微信公眾號“魚頭的Web海洋”。衷心希望可以遇見你。

純CSS實現表單驗證

相關文章