- 做者:陳大魚頭
- github: KRISACHAN
在咱們的平常業務中,表單驗證是個很常見設計需求,像一些登陸註冊框,問卷調查也都須要用到表單驗證。css
通常咱們的實現思路都是JS監聽input框的輸入內容,判斷用戶輸入內容,從而以此來決定下一步的操做。html
例如這樣:(如下例子來自優秀的開源UI庫,element)git
<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來實現呢?答案是能夠的。這裏先上DEMOgithub
上面的表單驗證就徹底是由CSS來實現的,核心屬性就是CSS Level 4
的Validity
。思路就是利用: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>
複製代碼
HTML5
裏<input>
的新屬性:pattern
MDN的解釋:api
檢查控件值的正則表達式.。pattern必須匹配整個值,而不單單是某些子集.。使用title屬性來描述幫助用戶的模式.。當類型屬性的值爲text, search, tel, url 或 email時,此屬性適用,不然將被忽略。(兼容ie10+)bash
備註:微信
pattern
裏的驗證規則不合法,例如多了長度校驗內多了空格,也是會在控制檯報錯的,詳情以下:<input data-title="帳號" pattern="/[\w]{6, 10}/" name="account" type="text" required />
複製代碼
CSS
與JS
裏的驗證規則不同,如下寫法是會無效的,核心校驗規則須要用[]
包起來(目前從測試的幾個例子是這樣,具體詳情還須要翻查資料,若是有大佬知道更具體的信息,請告知,謝謝!)<input data-title="帳號" pattern="/\w{6,10}/" name="account" type="text" required />
複製代碼
CSS Level 4 選擇器
的新屬性:invalid
詳細介紹請看個人博文[譯]19個CSS level 4 選擇器post
若是你喜歡探討技術,或者對本文有任何的意見或建議,很是歡迎加魚頭微信好友一塊兒探討,固然,魚頭也很是但願能跟你一塊兒聊生活,聊愛好,談天說地。 魚頭的微信號是:krisChans95 也能夠掃碼添加好友,備註「掘金」就行 測試