Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >AngularJS浏览器使用指令自动填充解决方法

AngularJS浏览器使用指令自动填充解决方法
EN

Stack Overflow用户
提问于 2013-02-19 19:40:24
回答 23查看 79K关注 0票数 111

在AngularJS中提交表单并使用浏览器的“记住密码”功能,并且在随后的登录尝试中让浏览器使用用户名和密码填写登录表单时,$scope模型不会根据自动填充进行更改。

我发现的唯一一个肮脏的方法是使用下面的指令:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
app.directive("xsInputSync", ["$timeout" , function($timeout) {
    return {
        restrict : "A",
        require: "?ngModel",
        link : function(scope, element, attrs, ngModel) {
            $timeout(function() {
                if (ngModel.$viewValue && ngModel.$viewValue !== element.val()) {
                    scope.apply(function() {
                        ngModel.$setViewValue(element.val());
                    });
                }
                console.log(scope);
                console.log(ngModel.$name);
                console.log(scope[ngModel.$name]);
            }, 3000);
        }
    };
}]);

问题是ngModel.$setViewValue(element.val());不会根据element.val()返回值更改模型或视图。我如何才能做到这一点?

EN

回答 23

Stack Overflow用户

发布于 2013-02-19 20:25:51

Apparently this is a known issue with Angular and is currently open

我不知道你在这里能做什么,除了一些你正在尝试的工作。看起来你是在正确的轨道上。我无法让我的浏览器尝试记住你的plunk的密码,所以我不确定这是否有效,但请看一下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
app.directive('autoFillSync', function($timeout) {
   return {
      require: 'ngModel',
      link: function(scope, elem, attrs, ngModel) {
          var origVal = elem.val();
          $timeout(function () {
              var newVal = elem.val();
              if(ngModel.$pristine && origVal !== newVal) {
                  ngModel.$setViewValue(newVal);
              }
          }, 500);
      }
   }
});
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<form name="myForm" ng-submit="login()">
   <label for="username">Username</label>
   <input type="text" id="username" name="username" ng-model="username" auto-fill-sync/><br/>
   <label for="password">Password</label>
   <input type="password" id="password" name="password" ng-model="password" auto-fill-sync/><br/>
   <button type="submit">Login</button>
</form>

我认为你只需要简化一下你的方法。我明确建议的一件事是检查ngModel.$pristine,并确保您没有覆盖一些糟糕的用户输入。而且,3秒可能太长了。你不应该在$timeout中调用$apply(),BTW,它应该自动为你排队一个$digest。

真正的陷阱:你的浏览器在执行时会胜过Angular吗?我的浏览器呢?

这可能是一场无法取胜的战争,这就是为什么Angular (或Knockout)不能轻易解决它的原因。不能保证在指令初始执行时输入中的数据的状态。甚至在Angular初始化的时候也不会...所以这是一个棘手的问题。

票数 45
EN

Stack Overflow用户

发布于 2013-11-08 08:28:13

您不需要使用$timeout或类似的东西。您可以使用事件系统。

我认为它更英国化,不依赖于jQuery或自定义事件捕获。

例如,在提交处理程序上:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$scope.doLogin = function() {
    $scope.$broadcast("autofill:update");

    // Continue with the login.....
};

然后你可以有一个像这样的autofill指令:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
.directive("autofill", function () {
    return {
        require: "ngModel",
        link: function (scope, element, attrs, ngModel) {
            scope.$on("autofill:update", function() {
                ngModel.$setViewValue(element.val());
            });
        }
    }
});

最后,您的HTML将如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<input type="text" name="username" ng-model="user.id" autofill="autofill"/>
票数 35
EN

Stack Overflow用户

发布于 2014-01-12 09:22:36

这里有一个解决方案,它比其他解决方案要简单得多,而且在语义上是合理的AngularJS:http://victorblog.com/2014/01/12/fixing-autocomplete-autofill-on-angularjs-form-submit/

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
myApp.directive('formAutofillFix', function() {
  return function(scope, elem, attrs) {
    // Fixes Chrome bug: https://groups.google.com/forum/#!topic/angular/6NlucSskQjY
    elem.prop('method', 'POST');

    // Fix autofill issues where Angular doesn't know about autofilled inputs
    if(attrs.ngSubmit) {
      setTimeout(function() {
        elem.unbind('submit').submit(function(e) {
          e.preventDefault();
          elem.find('input, textarea, select').trigger('input').trigger('change').trigger('keydown');
          scope.$apply(attrs.ngSubmit);
        });
      }, 0);
    }
  };
});

然后,您只需将该指令附加到表单:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<form ng-submit="submitLoginForm()" form-autofill-fix>
  <div>
    <input type="email" ng-model="email" ng-required />
    <input type="password" ng-model="password" ng-required />
    <button type="submit">Log In</button>
  </div>
</form>
票数 35
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14965968

复制
相关文章
安装libwxsmithlib-dev时提示“正试图覆盖...”的错误
正在解压缩 libwxsmithlib-dev (从 .../libwxsmithlib-dev_10.05-2_i386.deb) ... dpkg:处理 /var/cache/apt/archives/libwxsmithlib-dev_10.05-2_i386.deb (--unpack)时出错: 正试图覆盖 /usr/include/wxsmith/contrib/include/wx/propgrid/advprops.h,它同时被包含于软件包 wxsmith-headers 10.05-1 由于已经达到 MaxReports 限制,没有写入 apport 报告。
forrestlin
2022/04/02
9770
word在试图打开文件时遇到错误的解决办法
取消勾选第一个选项“为来自Internet的文件启用受保护的视图”,点击确定后退出,然后重新打开文件
全栈程序员站长
2022/09/01
2.6K0
word在试图打开文件时遇到错误的解决办法
word在试图打开文件时遇到错误,解决办法
取消勾选第一个选项“为来自Internet的文件启用受保护的视图”,点击确定后推出,然后重新打开文件
全栈程序员站长
2022/08/12
1.9K0
word在试图打开文件时遇到错误,解决办法
优雅的在终端中编写Python
專 欄 ❈PytLab,Python 中文社区专栏作者。主要从事科学计算与高性能计算领域的应用,主要语言为Python,C,C++。熟悉数值算法(最优化方法,蒙特卡洛算法等)与并行化 算法(MPI,OpenMP等多线程以及多进程并行化)以及python优化方法,经常使用C++给python写扩展。 blog:http://ipytlab.com github:https://github.com/PytLab ❈ 前言 最早我也只是在服务器上编辑文件的时候用用vim来改改程序,并没有把vim当做自己的主力
Python中文社区
2018/01/31
1.7K0
优雅的在终端中编写Python
优雅的在终端中编写Python
最早我也只是在服务器上编辑文件的时候用用vim来改改程序,并没有把vim当做自己的主力编辑器。但是偶然的一次机会需要改一个奇葩的输入文件的格式,用了下Vim的宏录制,尝到了甜头,于是后面就开始用Vim来写程序了,虽然使用初期有些阻力,但时间久了就会发现,双手再也不用离开键盘,即使使用sublime这样的编辑器我也要改成使用Vim模式,Vim真的能让自己一思维的速度编辑文本(对我来说就是写程序了)。
用户1332428
2018/07/26
1.8K0
优雅的在终端中编写Python
Word 在试图打开文件时遇到错误 解决办法
从网上下了个word文档,发现打开时提示文件打开遇到错误,提示的解决办法都无效,发到其他电脑上发现又能正常打开,于是确定是本机word设置有问题
全栈程序员站长
2022/08/11
1.5K0
Word 在试图打开文件时遇到错误 解决办法
word在试图打开文件时遇到错误,检查稳定或驱动器文件权限
我看很多人也是这问题,这种方案就可以解决。但我的是根本就没有“解除锁定”这一选项。
全栈程序员站长
2022/08/25
1.8K0
word在试图打开文件时遇到错误,检查稳定或驱动器文件权限
遇到“word在试图打开文件时遇到错误”怎么办?
1.打开文件遇到的错误提示“word在试图打开文件时遇到错误” 2.关闭这个提示窗口,打开左上角的文件按钮。 3.点击最下面的选项按钮,进入选项对话框, 4.点击左侧的信任中心,然后选择右侧的信任中心设置。 5.进入信任中心点击左侧的受保护试图选项卡,默认是三个选项都被选中。 6.取消勾选第一个选项“为来自internet的文件启用受保护的试图”,点击确认后退出,然后重新打开文件,看看是不是有效果了!
全栈程序员站长
2022/06/30
5.8K0
word输入矩阵卡死,导致word在试图打开文件时遇到错误
问题: 今天用office word 2019输入一个矩阵的时候,突然卡死了。强制关闭了word。再打开就变成这样了。
全栈程序员站长
2022/08/31
1.2K0
quartus ii运行错误_安装quartus时弹出错误
Info: ******************************************************************* Info: Running Quartus II 64-Bit Analysis & Synthesis Info: Version 11.0 Build 157 04/27/2011 SJ Full Version Info: Processing started: Thu May 15 13:09:59 2014 Info: Command: quartus_map –read_settings_files=on –write_settings_files=off simulate -c simulate Info: Parallel compilation is enabled and will use 2 of the 2 processors detected Info: Found 1 design units, including 1 entities, in source file simulate.v Info: Found entity 1: modelsim_test Error: Top-level design entity “simulate” is undefined
全栈程序员站长
2022/11/04
5.1K0
quartus ii运行错误_安装quartus时弹出错误
解决在打开word时,出现 “word 在试图打开文件时遇到错误” 的问题(亲测有效)[通俗易懂]
最近在网上查找期刊论文的模板时,发现从期刊官网下载下来的论文格式模板,在本地用word打开时,出现错误,情况如下
全栈程序员站长
2022/09/03
4.2K0
解决在打开word时,出现 “word 在试图打开文件时遇到错误” 的问题(亲测有效)[通俗易懂]
“word在试图打开文件时遇到错误”解决办法,亲测可用
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/130921.html原文链接:https://javaforall.cn
全栈程序员站长
2022/08/11
1.5K0
“word在试图打开文件时遇到错误”解决办法,亲测可用
Word——Word在试图打开文件时遇到错误的一种解决办法
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/132248.html原文链接:https://javaforall.cn
全栈程序员站长
2022/06/30
1.2K0
Word——Word在试图打开文件时遇到错误的一种解决办法
word在试图打开文件时遇到错误,一种解决办法[通俗易懂]
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/135545.html原文链接:https://javaforall.cn
全栈程序员站长
2022/09/05
1.7K0
word在试图打开文件时遇到错误,一种解决办法[通俗易懂]
关于首次运行Hadoop的Grep案例时出现的错误
重点关注这句“19/05/14 18:26:55 INFO metrics.MetricsUtil: Unable to obtain hostName java.net.UnknownHostException: hadoop101: hadoop101: Temporary failure in name resolution”,其为hostname可能存在问题,因此去查看/etc/sysconfig/network文件和/etc/hosts文件,发现其network文件中的“HOSTNAME=”后多打了一个空格,把其去掉,即可,问题解决
可定
2020/04/20
4.4K0
office xls 文件已损坏 无法打开 word在试图打开文件时遇到错误
转自:http://windyli.blog.51cto.com/1300305/326491
全栈程序员站长
2022/09/01
2.5K0
Word 在试图打开文件时遇到错误 文档可能已损坏 解决方法
我使用的是 Office 2019 的 Word 打开后缀名为 doc 的文件。
wsuo
2021/03/18
8.4K0
Word 在试图打开文件时遇到错误 文档可能已损坏 解决方法
word2007在试图打开文件时遇到错误解决方法「建议收藏」
当您尝试在 Microsoft Office Word 2007 中打开 .docx 文件时,该文件打不开。此外,您还会收到以下错误消息: Word 在试图打开文件时遇到错误。 请尝试下列方法: * 检查文档或驱动器的文件权限。 * 确保有足够的内存和磁盘空间。 * 用文本恢复转换器打开文件。
全栈程序员站长
2022/09/02
2.7K0
编写Docker Compose时要注意的五大常见错误
在构建容器化的应用时,开发人员往往需要某种方法来引导启动目标容器,以对其进行代码级别的测试。尽管业界有许多方法可以实现该目的,但Docker Compose是目前最受欢迎的一种方法。它能够让如下两个方面变得容易实现:
Java帮帮
2020/08/21
2.2K1
编写Docker Compose时要注意的五大常见错误
点击加载更多

相似问题

ASP.NET C#捕获类中的所有异常

50

在ASP.NET MVC + Web中捕获所有异常

11

MVC Winforms c#空引用异常

21

WinForms和Asp类库中的异常处理

40

捕获类中的所有异常

21
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文