溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

純CSS怎樣實(shí)現(xiàn)表單驗(yàn)證

發(fā)布時(shí)間:2021-03-19 09:50:13 來(lái)源:億速云 閱讀:144 作者:小新 欄目:web開(kāi)發(fā)

這篇文章將為大家詳細(xì)講解有關(guān)純CSS怎樣實(shí)現(xiàn)表單驗(yàn)證,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

在我們的日常業(yè)務(wù)中,表單驗(yàn)證是個(gè)很常見(jiàn)設(shè)計(jì)需求,像一些登錄注冊(cè)框,問(wèn)卷調(diào)查也都需要用到表單驗(yàn)證。

一般我們的實(shí)現(xiàn)思路都是JS監(jiān)聽(tīng)input框的輸入內(nèi)容,判斷用戶輸入內(nèi)容,從而以此來(lái)決定下一步的操作。

例如這樣:(以下例子來(lái)自優(yōu)秀的開(kāi)源UI庫(kù),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: '年齡必須為數(shù)字值'}
    ]"
  >
    <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>

以上就是我們常規(guī)的表達(dá)驗(yàn)證了,基本就都是用JS來(lái)完成的,那么我們能不能用CSS來(lái)實(shí)現(xiàn)呢?答案是可以的。這里先上DEMO

CSS實(shí)現(xiàn)表單驗(yàn)證

上面的表單驗(yàn)證就完全是由CSS來(lái)實(shí)現(xiàn)的,核心屬性就是 CSS Level 4Validity 。思路就是利用 :valid:invalid 可以對(duì) <input>value 進(jìn)行判斷的特性。

這里是全部代碼

/*
 * 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">
    賬號(hào):
    <input data-title="賬號(hào)" pattern="[\w]{6,10}" name="account" type="text" required />
    <span class="f-tips">請(qǐng)輸入正確的賬號(hào)</span>
    <br />
    密碼:
    <input data-title="密碼" pattern="[\w]{6,10}" name="password" type="password" required />
    <span class="f-tips">請(qǐng)輸入正確的密碼</span>
    <br />
    <input name="button" type="submit" value="提交" />
</form>

效果截圖

純CSS怎樣實(shí)現(xiàn)表單驗(yàn)證 

純CSS怎樣實(shí)現(xiàn)表單驗(yàn)證 

使用到的知識(shí)點(diǎn)

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

MDN的解釋:

檢查控件值的正則表達(dá)式.。pattern必須匹配整個(gè)值,而不僅僅是某些子集.。使用title屬性來(lái)描述幫助用戶的模式.。當(dāng)類型屬性的值為text, search, tel, url 或 email時(shí),此屬性適用,否則將被忽略。(兼容ie10+)

備注:

如果 pattern 里的驗(yàn)證規(guī)則不合法,例如多了長(zhǎng)度校驗(yàn)內(nèi)多了空格,也是會(huì)在控制臺(tái)報(bào)錯(cuò)的,詳情如下:

純CSS怎樣實(shí)現(xiàn)表單驗(yàn)證

<input data-title="賬號(hào)" pattern="/[\w]{6, 10}/" name="account" type="text" required />

CSSJS 里的驗(yàn)證規(guī)則不一樣,以下寫(xiě)法是會(huì)無(wú)效的,核心校驗(yàn)規(guī)則需要用 [] 包起來(lái)(目前從測(cè)試的幾個(gè)例子是這樣,具體詳情還需要翻查資料,如果有大佬知道更具體的信息,請(qǐng)告知,謝謝?。?/p>

<input data-title="賬號(hào)" pattern="/\w{6,10}/" name="account" type="text" required />

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

關(guān)于“純CSS怎樣實(shí)現(xiàn)表單驗(yàn)證”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

css
AI