摘要:表單和其中的表單控件提供了驗證服務(wù),可以讓用戶在提交一般在點擊類型為的按鈕時提交表單前意識到自己有非法不符合要求,以下都將稱為非法的輸入。為了編寫一個可靠的應(yīng)用程序,服務(wù)端驗證是不可或缺的。促發(fā)條件至于自定義表單驗證,我會另寫一篇。
表單
網(wǎng)頁中用戶于服務(wù)端交互數(shù)據(jù)的表單控件有input、select、textarea,而表單是將為了達到一個目的(登錄、注冊等)各種控件整合到一起的一個集合。
表單和其中的表單控件提供了驗證服務(wù),可以讓用戶在提交(一般在點擊類型為submit的按鈕時提交)表單前意識到自己有非法(不符合要求,以下都將稱為非法)的輸入。這種驗證方式(客戶端驗證)提供了比多帶帶的服務(wù)端驗證更好的用戶體驗,因為用戶在輸入后得到實時的反饋,修正輸入的信息。
但是雖然說客戶端驗證提供了更好的用戶體驗,但是服務(wù)端驗證也是不可或缺的,因為客戶端驗證并不可靠而且很容易被繞過。為了編寫一個可靠的應(yīng)用程序,服務(wù)端驗證是不可或缺的。
用于理解雙向數(shù)據(jù)綁定的關(guān)鍵指令是ngModel(指令在視圖中使用時需要將大寫字母裝換為-x,例如ng-model),ngModel(ngBind)指令提供了模型與視圖之間的雙向數(shù)據(jù)綁定的方法。另外,ngModel為其他指令擴展其行為提供了API(應(yīng)用程序編程接口)。
user:{{ user | json }}
User:{{ User | json }}
這里有幾個需要注意的點:
novalidate是用來禁用瀏覽器自帶的驗證。
ngModel的值不會被設(shè)置,直到通過了控件的驗證,比如說type=email必須為xxx@xxx的形式,可以仔細看下方user中email字段的變化。
建議不要使用type=reset的按鈕,會將輸入框清空,但不會重置數(shù)據(jù)模型中的值,原因未知。
使用css樣式在不同的驗證狀態(tài)下,ngModel為控件和表單提供了一些css類(需要在樣式表中聲明):
ng-valid:數(shù)據(jù)模型合法
ng-invalid:數(shù)據(jù)模型不合法
ng-valid-[key]:每一個通過$setValidity添加的合法鍵
ng-invalid-[key]:每一個通過$setValidity添加的不合法的鍵
ng-pristine:還沒有與用戶交互(輸入過)的控件
ng-dirty:與用戶交互過的控件
ng-touched:失去過焦點的控件(鼠標(biāo)點上去獲得,點其他地方失去)
ng-untouched:沒有失去過焦點的控件
ng-pending:任何沒有結(jié)束(與服務(wù)端交互)的異步驗證
這里簡單的演示ng-invalid和ng-touched
html:
css:
.ng-invalid.form-control { border-color: #E96666; box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(233, 102, 102, 0.6) } .ng-touched.form-control { border-color: #66E985; box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102, 233, 160, 0.6) }
第一個輸入框因為是必須的,所以是非法的狀態(tài),所以angular會給這個控件添加ng-invalid樣式,在輸入后變?yōu)楹戏?該樣式去除,在失去焦點后ng-touched樣式添加
表單是FormController的一個實例,我們可以用表單的name屬性將表單暴露到作用域中。
相似的,一個有數(shù)據(jù)綁定(有ngModel)的表單控件也是NgModelController的實例,也可以通過表單實例的屬性(控件的name)暴露到作用域中。
我們可以通過這個特性擴展我們上一個例子:
在用戶與表單控件交互后再展示錯誤信息
在用戶點擊提交之后再展示錯誤信息
注意一下,$submitted表示是否點擊過提交(type=submit)按鈕,開發(fā)遇到問題的時候,大家也可以把$error打印出來看下,表單和表單中的控件都有$error對象,這里我都打印出來了
在默認情況下,對數(shù)據(jù)的任何改變都會促發(fā)模板的更新和表單驗證。我們可以使用ngModelOptions指令去重寫這個行為,使只有在特定的條件下才觸發(fā)。
比如說
ng-model-options="{ updateOn: "blur" }"
會只在表單控件失去焦點時觸發(fā),我們也可以設(shè)置多個事件來觸發(fā),只要使用空格隔開即可
ng-model-options="{ updateOn: "mousedown blur" }"
如果想把原有的保存,只是想加一個觸發(fā)條件的話,可以加上default在列表中
ng-model-options="{ updateOn: "default blur" }"
一個完整點的例子:
html:
我們可以通過ngModelOptions的debounce 關(guān)鍵字來使數(shù)據(jù)綁定延遲,這個延遲對解析器,驗證和表單的屬性($dirty,$pristine等)都會生效。
寫法也很簡單
ng-model-options="{ debounce: 500 }"
ngModelOptions是可以繼承的,所以如果有多個控件都需要這個效果,可以在他們的父元素上添加這個指令,除非子元素重寫這個屬性。
促發(fā)條件: blur
{{ user.name }}
至于自定義表單驗證,我會另寫一篇。剛開博客沒多久,希望大家有任何問題或者意見都在下方提出,或者加我qq 651882883。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/115296.html
摘要:表單驗證表單驗證是一項重要的功能,能保證我們的應(yīng)用不會被惡意或錯誤的輸入破壞。給加上意味著表單的名稱是。驗證提示這是在版本之后對表單驗證的優(yōu)化。 表單驗證 表單驗證是angularJS一項重要的功能,能保證我們的web應(yīng)用不會被惡意或錯誤的輸入破壞。Angular表單驗證提供了很多表單驗證指令,并且能將html5表單驗證功能同他自己的驗證指令結(jié)合起來使用,進而在客戶端驗證時提供表單狀態(tài)...
ngVerify v1.5.6 a easy AngularJS Form Validation plugin.簡潔高效的__表單驗證插件__ See how powerful it.看看它有多強大 動態(tài)校驗 自動關(guān)聯(lián)提交按鈕 多種 tip 校驗消息提示 不只校驗 dom 元素值,還可以校驗 ngModel 數(shù)據(jù)模型 支持任意類型表單元素,甚至可以校驗非表單元素 提供 type 類型校驗?zāi)0?..
摘要:如果想要屏蔽瀏覽器對表單的默認驗證行為,可以在表單元素上添加標(biāo)記。如果未修改,值為,如果修改過值為修改過的表單只要用戶修改過表單,無論輸入是否通過驗證,該值都返回合法的表單這個布爾型的屬性用來判斷表單的內(nèi)容是否合法。 借助AngularJS,我們不需要花太多額外的精力就可以輕松實現(xiàn)客戶端表單驗證功能。雖然 Web應(yīng)用安全不能完全依賴客戶端驗證,但客戶端驗證可以提供表單狀態(tài)的實時反饋。 ...
摘要:表單和其中的表單控件提供了驗證服務(wù),可以讓用戶在提交一般在點擊類型為的按鈕時提交表單前意識到自己有非法不符合要求,以下都將稱為非法的輸入。為了編寫一個可靠的應(yīng)用程序,服務(wù)端驗證是不可或缺的。促發(fā)條件至于自定義表單驗證,我會另寫一篇。 表單 網(wǎng)頁中用戶于服務(wù)端交互數(shù)據(jù)的表單控件有input、select、textarea,而表單是將為了達到一個目的(登錄、注冊等)各種控件整合到一起的一個...
閱讀 4627·2021-09-26 09:55
閱讀 1369·2019-12-27 12:16
閱讀 890·2019-08-30 15:56
閱讀 1908·2019-08-30 14:05
閱讀 995·2019-08-30 13:05
閱讀 1271·2019-08-30 10:59
閱讀 1447·2019-08-26 16:19
閱讀 1889·2019-08-26 13:47