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