什麼是 Validate.JS Validate.JS  是一個表單驗證的函式庫,使用 Validate.JS 可以讓我們方便、快速的完成表單驗證的功能!點擊這裡 可以先查看官網的簡易範例。
如何使用 Validate.JS 下載 Validate.JS 首先,我們可以透過不同的方式下載  Validate.JS
CDN 1 <script src="https//cdnjs.cloudflare.com/ajax/libs/validate.js/0.13.1/validate.min.js" >        </script>
 
npm 1 2 $npm install --save validate.jsvar  validate = require ("validate.js" );
 
 
使用 Validate.JS 驗證欄位是否填寫 這邊先來介紹一下 validate.js 驗證器的基本格式,1 2 3 4 5 6 7 <attribute>: { 
1 2 3 4 username : { presence : true , 
驗證器(validator)和驗證器選項(validator options)有很多。首先,我們先練習使用 Validate.JS 幫助我們判斷欄位是否填寫,我們需要用validate()函示來驗證欄位,帶入的參數如下:
1 2 
這裡的屬性(attributes)可以帶入物件 或是表單(form)元素 ,如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 let  constraints = {name : {presence : true  username : "nick" , password : "better" }, constraints);const  form = document .querySelector("#form" );
validate() 執行後,驗證屬性,回傳錯誤訊息(如果沒有錯誤就不會回傳任何結果)
1 2 3 4 5 6 7 8 9 10 11 let  constraints = {name : {presence : true  name : "nick" }, constraints);name : "" }, constraints);
注意:
原因是, null 和 undefined 是合法的值,所以如果不希望使用者輸入空的值,就要記得加上 presence: true。
 
了解了 validate() 的用法後,就可以搭配 form 標單寫成如下:
  See the Pen 
  validate.js  範例一  by 蔡蔡 Mavis (@0430shinyu )
  on CodePen . 
送出空白欄位後,我們就可以在 console 面板看到回傳錯誤提示物件(若欄位填寫正確則會回傳 undefined。):
使用 Validate.JS 驗證欄位各種情境 除了驗證欄位是否填寫以外,Validate.JS 還包含了以下不同種的驗證:
1. datetime 
datetime 可以用來驗證日期和時間。
在使用此驗證器之前,我們需要設置 parse 和 format 函數,https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.10.6/moment.min.js )
moment.js 是一切和時間有關的的解析、轉換、設置、格式化日期的 JavaScript 函式庫
 
1 2 3 4 5 6 7 8 9 validate.extend(validate.validators.datetime, {parse : function (value, options ) return  +moment.utc(value);format : function (value, options ) var  format = options.dateOnly ? "YYYY-MM-DD"  : "YYYY-MM-DD hh:mm:ss" ;return  moment.utc(value).format(format);
之後就可以使用 datetime: true 判斷是否符合格式 YYYY-MM-DD 或 YYYY-MM-DD hh:mm:ss,另外,也可以加上 dateOnly: true 限制只判斷格式是否符合 YYYY-MM-DD
1 2 3 4 5 validate({departure : "2013-12-11 10:09:08" }, {departure : {datetime : true }});departure : "2013-12-11 10:09:08" }, {departure : {datetime : {dateOnly : true }}});
我們也可以搭配 moment.js  和 latest(日期前)與 earliest(日期後) 做年齡的判斷
1 2 3 4 5 6 7 8 9 10 11 var  constraints = {birthday : {datetime : {dateOnly : true , latest : moment.utc().subtract(18 , 'years' ), message : "^You need to be at least 18 years old"  birthday : "3013-11-14" }, constraints);
2. email 
email 可以判斷信箱是否為有效格式
1 2 3 4 5 6 7 8 9 10 11 12 13 let  constraints = {from : {email : true from : "nicklas@ansman" }, constraints);from : "NICKLAS@ANSMAN.SE" }, constraints);
email 一樣也可以透過 message 回傳錯誤訊息,如果希望 messsage 省略預設的屬性名稱(form)可以加上 ^ 寫成 “^doesn’t look like a valid email”。
1 2 3 4 5 6 7 8 9 10 constraints = {from : {email : {message : "doesn't look like a valid email" from : "foobar" }, constraints);
3.equality 
1 2 3 4 5 6 7 8 9 10 11 let  constraints = {confirmPassword : {equality : "password"  password : "foo" , confirmPassword : "foo" }, constraints);password : "foo" , confirmPassword : "bar" }, constraints);
4.exclusion 
1 2 3 4 5 6 7 8 var  restrictedDomains = ;subdomain : "tw" }, {subdomain : {exclusion : ["jp" , "ch" ]}});subdomain : "jp" }, {subdomain : {exclusion : ["jp" , "ch" ]}});
我們也可以使用 within 搭配 ${value} 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 let  constraints = {subdomain : {exclusion : {within : {jp : "Japan" , ch : "China" },message : "^We don't support %{value} right now, sorry" subdomain : "jp" }, constraints);subdomain : "com" }, constraints);
5.inclusion 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 let  sizes = ["small" , "medium" , "large" ];"small" }, {size : {inclusion : sizes}});size : "xlarge" }, {size : {inclusion : sizes}});let  constraints = {size : {inclusion : {within : {"Small" : "s" , "Medium" : "m" , "Large" : "l" },message : "^We're currently out of %{value}" size : "Extra large" }, constraints);size : "Medium" }, constraints);
6.format 
1 2 3 4 5 6 7 let  pattern = /\d{5}(-\d{4})?/ ;zipCode : "foobar" }, {zipCode : {format : pattern}});zipCode : "12345" }, {zipCode : {format : pattern}});
如果需要使用到 flags 需要再另外加上
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 var  constraints = {username : {format : {pattern : "[a-z0-9]+" ,flags : "i" ,message : "can only contain a-z and 0-9" username : "Nicklas!" }, constraints);username : "Nicklas" }, constraints);
7.length 
length 可以用來判斷是否符合長度,is 代表等於,代表小於,代表大於,也可使用
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 let  constraints = {key1 : {length : {is : 3 }}, key2 : {length : {minimum : 20 }}, key3 : {length : {maximum : 3 }}, key4 : {length : {minimum : 3 , tooShort : "needs to have %{count} words or more" , tokenizer : function (value ) return  value.split(/\s+/g );var  values = {key1 : "wrong length" ,key2 : "too short" ,key3 : "too long" ,key4 : "too short" 
8.numericality 
numericality可以判斷是否只填入數字,沒有填入其他型態的內容。
1 2 3 4 5 6 7 8 validate({duration : "foobar" }, {duration : {numericality : true }});duration : "3" }, {duration : {numericality : true }});duration : "03" }, {duration : {numericality : true }});
strict:數字不可以0作為開頭
1 2 validate({duration : "03" }, {duration : {numericality : {strict : true }}});
noStrings:數字不可以0作為開頭
1 2 3 4 5 validate({duration : "3" }, {duration : {numericality : {noStrings : true }}});duration : 3 }, {duration : {numericality : {noStrings : true }}})
noStrings:數字可以整除數字 n
1 2 validate({duration : "7" }, {duration : {numericality : {divisibleBy : 3 }}});
還有其他不同的設定:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 var  constraints = {duration : {numericality : {onlyInteger : true ,greaterThan : 0 , lessThanOrEqualTo : 30 , even : true , notEven : "must be evenly divisible by two"  duration : 3.14 }, constraints);duration : 4711 }, constraints);
9.url 
url 可以判斷網址是否有效。
1 2 3 4 5 6 7 8 validate({website : "http://google.com" }, {website : {url : true }});website : "google.com" }, {website : {url : true }});website : "ftp://google.com" }, {website : {url : true }});
schemes :允許的 schemes,預設為 [“http”, “https”]。
1 2 3 4 5 6 7 8 validate({website : "ftp://google.com" }, {website : {url : {schemes : ["ftp" ]
allowLocal:允許 local 主機名稱,如:10.0.1.1 或 localhost。預設為 false
1 2 3 4 5 6 7 8 9 10 11 validate({website : "http://localhost" }, {website : {url : true }});website : "http://localhost" }, {website : {url : {allowLocal : true 
回傳結果給使用者 前面我們已經了解到如何使用 Validate.js 做驗證,但只在 console 面板顯示錯誤提示,無法真正提醒使用者。我們可以透過點擊送出按鈕後隱藏、顯示文字來提醒使用者,例如:
  See the Pen 
  validate.js  範例二  by 蔡蔡 Mavis (@0430shinyu )
  on CodePen . 
參考資料 Validate.JS 官網