純CSS實(shí)現(xiàn)表單驗(yàn)證的示例代碼
在我們的日常業(yè)務(wù)中,表單驗(yàn)證是個(gè)很常見設(shè)計(jì)需求,像一些登錄注冊框,問卷調(diào)查也都需要用到表單驗(yàn)證。
一般我們的實(shí)現(xiàn)思路都是JS監(jiān)聽input框的輸入內(nèi)容,判斷用戶輸入內(nèi)容,從而以此來決定下一步的操作。
例如這樣:(以下例子來自優(yōu)秀的開源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: '年齡必須為數(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來完成的,那么我們能不能用CSS來實(shí)現(xiàn)呢?答案是可以的。這里先上DEMO
CSS實(shí)現(xiàn)表單驗(yàn)證
上面的表單驗(yàn)證就完全是由CSS來實(shí)現(xiàn)的,核心屬性就是 CSS Level 4 的 Validity 。思路就是利用 :valid 跟 :invalid 可以對 <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">請輸入正確的賬號(hào)</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>
效果截圖
使用到的知識(shí)點(diǎn)
1. HTML5 里 <input> 的新屬性: pattern
MDN的解釋:
檢查控件值的正則表達(dá)式.。pattern必須匹配整個(gè)值,而不僅僅是某些子集.。使用title屬性來描述幫助用戶的模式.。當(dāng)類型屬性的值為text, search, tel, url 或 email時(shí),此屬性適用,否則將被忽略。(兼容ie10+)
備注:
如果 pattern 里的驗(yàn)證規(guī)則不合法,例如多了長度校驗(yàn)內(nèi)多了空格,也是會(huì)在控制臺(tái)報(bào)錯(cuò)的,詳情如下:

<input data-title="賬號(hào)" pattern="/[\w]{6, 10}/" name="account" type="text" required />
CSS 與 JS 里的驗(yàn)證規(guī)則不一樣,以下寫法是會(huì)無效的,核心校驗(yàn)規(guī)則需要用 [] 包起來(目前從測試的幾個(gè)例子是這樣,具體詳情還需要翻查資料,如果有大佬知道更具體的信息,請告知,謝謝?。?/p>
<input data-title="賬號(hào)" pattern="/\w{6,10}/" name="account" type="text" required />
2. CSS Level 4 選擇器 的新屬性: invalid
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
css騷操作表單驗(yàn)證功能的實(shí)現(xiàn)代碼
這篇文章主要介紹了css騷操作表單驗(yàn)證功能的實(shí)現(xiàn)代碼,需要的朋友可以參考下2019-08-07css隱藏移動(dòng)端滾動(dòng)條并且ios上平滑滾動(dòng)的方法
這篇文章主要介紹了css隱藏移動(dòng)端滾動(dòng)條并且ios上平滑滾動(dòng)的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-01-23
能用CSS實(shí)現(xiàn)的就不要麻煩JavaScript了
雖然萬物都可以是JavaScript,但某種程度css的運(yùn)行效率會(huì)比JavaScript高,所以筆者認(rèn)為:能用CSS實(shí)現(xiàn)的就不用麻煩JavaScript2021-09-28


