讓angularjs支持瀏覽器自動(dòng)填表
最近有很多前端同學(xué)都抱怨說,登陸表單都不能記錄自己的賬號(hào)。這對(duì)于用單頁面(single-page applications)和使用ajax比較多的網(wǎng)頁來說,還是一個(gè)蠻普遍的問題。
UserApp是一個(gè)使用angularjs構(gòu)建的WebApp,但是他一直未能支持瀏覽器的"save password"特性。
下面就列出了一些發(fā)現(xiàn)的問題:
表單不能用js動(dòng)態(tài)的插入DOM。
表單必須真正的發(fā)出一個(gè)POST請(qǐng)求。(不能獲取表單內(nèi)容,然后用ajax發(fā)出請(qǐng)求)
當(dāng)瀏覽器自動(dòng)填表后,$scope并不能獲得更新后的數(shù)據(jù)。
Firefox相對(duì)來說簡(jiǎn)單一點(diǎn),只要表單元素有name屬性,觸發(fā)提交事件之后,它就會(huì)自動(dòng)提醒用戶是否記錄數(shù)據(jù)。
<form name="login-form" ng-submit="login()">
<input id="login" name="login" type="text" ng-model="user.login">
<input id="password" name="password" type="password" ng-model="user.password">
</form>
firefox記錄數(shù)據(jù)的要求比較簡(jiǎn)單
但是firefox有一個(gè)問題,在自動(dòng)填表之后,$scope里的數(shù)據(jù)并不會(huì)更新。所以我google了一下,發(fā)現(xiàn)了一些針對(duì)此問題的hacks。但是總感覺這些解決方案沒必要,因?yàn)槲倚枰闹皇窃谔峤槐韱蔚臅r(shí)候?qū)?shù)據(jù)帶上,而不是一些很溜逼的數(shù)據(jù)雙向綁定技術(shù)。所以我就采用了很簡(jiǎn)單的辦法:在提交表單的時(shí)候獲取表單元素的值。
$scope.login = function() {
$scope.user = {
login: $("#login").val(),
password: $("#password").val()
};
...
return false;
};
OK,現(xiàn)在firefox沒問題了,但是chrome怎么辦呢?
chrome只有在form表單真正發(fā)起POST請(qǐng)求的時(shí)候才會(huì)提示用戶是否儲(chǔ)存密碼,但這樣的話就不能用Ajax操作了。
下面是解決辦法:
當(dāng)表單發(fā)出Post請(qǐng)求時(shí),用ng-submit截取,返回false將其阻止,同時(shí)用ajax提交數(shù)據(jù)。
當(dāng)ajax成功返回時(shí),將session儲(chǔ)存在cookies里,再將表單重新提交一邊。
頁面重載的時(shí)候會(huì)發(fā)現(xiàn)已經(jīng)認(rèn)證過了,就將其重定向到主頁。
這會(huì)讓頁面刷新一次,但也就是登錄的時(shí)候需要刷新而已,確保頁面返回時(shí)是同一個(gè)地址就行了。
但如果表單是被動(dòng)態(tài)添加進(jìn)DOM的時(shí)候,這個(gè)方法仍然不行。解決方案就是在index.html中添加一個(gè)隱藏的表單,需要提交數(shù)據(jù)的時(shí)候就將其它表單攜帶的數(shù)據(jù)復(fù)制到隱藏表單里。
我將它打包成了一個(gè)directive:
app.directive("ngLoginSubmit", function(){
return {
restrict: "A",
scope: {
onSubmit: "=ngLoginSubmit"
},
link: function(scope, element, attrs) {
$(element)[0].onsubmit = function() {
$("#login-login").val($("#login", element).val());
$("#login-password").val($("#password", element).val());
scope.onSubmit(function() {
$("#login-form")[0].submit();
});
return false;
};
}
};
});
在index.html里隱藏的表單:
<form name="login-form" id="login-form" method="post" action="" style="display: none;">
<input name="login" id="login-login" type="text">
<input name="password" id="login-password" type="password">
</form>
臨時(shí)登錄表單
<form name="login-form" autocomplete="on" ng-login-submit="login">
<input id="login" name="login" type="text" autocomplete="on">
<input id="password" name="password" type="password" autocomplete="on">
</form>
登錄用的controller:
$scope.login = function(submit) {
$scope.user = {
login: $("#login").val(),
password: $("#password").val()
};
function ajaxCallback() {
submit();
}
return false;
};
刷新時(shí)會(huì)提示是否重新提交表單
現(xiàn)在這個(gè)問題解決了,但是每當(dāng)你按下f5的時(shí)候,瀏覽器都會(huì)提醒你要不要重新提交表單。這確實(shí)有點(diǎn)蛋疼,所以我添加了一個(gè)pre-login.html文件,隱藏的表單會(huì)提交數(shù)據(jù)到這里,然后再重定向到index.html。
現(xiàn)在OK了~
相關(guān)文章
詳解angularjs獲取元素以及angular.element()用法
本篇文章主要介紹了詳解angularjs獲取元素以及angular.element()用法 ,具有一定的參考價(jià)值,有興趣的可以了解一下2017-07-07angularJs中$http獲取后臺(tái)數(shù)據(jù)的實(shí)例講解
今天小編就為大家分享一篇angularJs中$http獲取后臺(tái)數(shù)據(jù)的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-08-08Angularjs之ngModel中的值驗(yàn)證綁定方法
今天小編就為大家分享一篇Angularjs之ngModel中的值驗(yàn)證綁定方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09用WebStorm進(jìn)行Angularjs 2開發(fā)(環(huán)境篇:Windows 10,Angular-cli方式)
這篇文章主要介紹了用WebStorm進(jìn)行Angularjs 2開發(fā)(環(huán)境篇:Windows 10,Angular-cli方式),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-12-12AngularJS實(shí)現(xiàn)路由實(shí)例
本文給大家分享的是使用angularjs路由框架實(shí)現(xiàn)的一個(gè)簡(jiǎn)單頁面跳轉(zhuǎn)功能,非常的實(shí)用,也很詳細(xì),有需要的小伙伴可以參考下2017-02-02Angular2 父子組件數(shù)據(jù)通信實(shí)例
這篇文章主要介紹了Angular2 父子組件數(shù)據(jù)通信實(shí)例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-06-06angularjs實(shí)現(xiàn)對(duì)表單輸入改變的監(jiān)控(ng-change和watch兩種方式)
這篇文章主要介紹了angularjs通過ng-change和watch兩種方式實(shí)現(xiàn)對(duì)表單輸入改變的監(jiān)控,需要的朋友可以參考下2018-08-08