angularjs ng-option ie issue解决方案

简介:

最近遇见angularjs 在IE上当使用ng-options作为select的选项数据源,并且被套在ng-switch(ng-transclude)之类的,当angular上得ng-options数据源model改变后,在IE上并不渲染。

在一阵的测试和阅读相关文档后最后确认为:因为ng-switch(ng-transclude)是为了使其scope为原来的父scope,在父scope上生成了DOM后才克隆(cloneNode)到指定的指令位置。然而IE在对于select克隆的节点,不会主动去触发重绘,所以才有了上面的issue。

问题确定了,那我们所需要做的就是手动的去触发让IE对Select重绘,尝试了很多办法后最终确认有效的是:首先在options上用原生js去添加一个option,在马上移除掉这个option,所以解决方案如下:

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
31
32
33
34
35
36
37
38
39
40
41
angular.module( 'ie.select' , [])
 
.directive( 'ieSelectFix' , [
 
     function  () {
 
         return  {
 
             restrict:  'A' ,
 
             require:  'select' ,
 
             link:  function  (scope, element, attributes) {
 
                 var  isIE = document.attachEvent;
 
                 if  (!isIE)  return ;
 
  
 
                 var  control = element[0];
 
                 scope.$watch(attributes.ieSelectFix,  function  () {
 
                     //it should be use javascript way, not jquery way.
 
                     var  option = document.createElement( "option" );
 
                     control.add(option,  null );
 
                     control.remove(control.options.length - 1);
 
                 });
 
             }
 
         }
 
     }
 
]);

  

使用方式如下:

1
2
3
4
5
6
7
< select  ie-select-fix="options" ng-model="demos" class="form-control"
 
         ng-options="currOption.value as currOption.text for currOption in options">
 
     < option  value="" default>Select</ option >
 
</ select >

  

我也在我的github专门创建了一个针对angularjs在IE上issue的项目,收录了这个指令,在后续也会加入我所遇见的angularjs关于ie的issue,也希望大家帮助完善这个项目,让我们的angularjs程序在IE工作的更美好,让我们这些辛苦的程序猿也少一点加班时间,多一点陪家人,泡咖啡的时间。哈哈。

github项目地址:https://github.com/greengerong/angular-ie-enhancer


本文转自破狼博客园博客,原文链接:http://www.cnblogs.com/whitewolf/p/3464053.html,如需转载请自行联系原作者

目录
相关文章
|
JavaScript
ie8 ie浏览器下载excel文件乱码,变成压缩包,解决方案
ie8 ie浏览器下载excel文件乱码,变成压缩包,解决方案
173 0
|
安全
Selenium在Win10下IE浏览器遇到的白屏初始页面解决方案
开发环境:Win10+Python3.5+Selenium+IE11硬件环境:联想MIIX700语言环境:English(US)在做数据爬取得时候,发现IE Driver出现白屏,跟着提示:“This is the initial start page for the WebDriver server“几经寻找,解决了问题。
1835 0
IE6下focus与blur错乱的解决方案
Miller同学发现的IE6 bug:如以下代码,点击textarea时,引发window的blur,导致focus与blur配对混乱: hello window.onblur=function(){ document.title= 'blur:' + Math.random() ; } window.onfocus=function(){ document.title= 'focus:' + Math.random() ; } 这应该是一个很常见的需求,例如,当前窗口定期更新数据,而窗口失焦则减少信息更新频率。
699 0
|
Web App开发 JavaScript 前端开发
Vue 兼容 ie9 的全面解决方案
Vue 官方对于 ie 浏览器版本兼容情况的描述是 ie9+,即是 ie9 及更高的版本。经过测试,Vue 的核心框架 vuejs 本身,以及生态的官方核心插件(VueRouter、Vuex等)均可以在 ie9 上正常使用。
2352 0
IE DIV背景透明,点击事件不响应解决方案
IE DIV背景透明,给DIV绑定点击事件,   $("div").bind("click", function(){ alert('click me.'); });     当点击DIV时,不会响应已经绑定的点击事件。
891 0
|
Web App开发 移动开发 JavaScript
让所有IE支持HTML5的解决方案
引用:http://blog.bingo929.com/html5-ie-enabling-script.html  自从HTML5能为我们的新网页带来更高效洁净的代码而得到更多的关注,然而唯一能让IE识别那些新元素(如)的途径是使用HTML5 shiv,感谢remy sharp为我们提供了这个迷你脚本来解决IE支持HTML5的问题。
885 0
Joomla模板IE6下PNG透明,但无法点击链接的解决方案
解决ie6无法显示PNG背景图片透明问题的方法就是用 “filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(enabled=true, sizingMethod=scale, src=’images/liBack.png’,no-repeat); background:none;”。
675 0
|
Web App开发 PHP 关系型数据库
PHPExcel导出(import)xls文件到浏览器,IE与Firefox等通用解决方案
PHPExcel是微软认证的一个PHP操作Excel表格的类库,功能强大,所有Excel类型都支持。    在实际使用中,从Excel导入数据至MySQL没有什么问题,但导出成xls文件至浏览器,让用户自我选择下载这一既实用又简单的功能在IE中却无法实现,不是出现错误就是给个白屏。
1184 0
Win2003下Loadrunner9.1 脚本录制时IE出现WIN32异常解决方案
Win2003下Loadrunner9.1 脚本录制时无法自动打开IE 遇到的问题: 每次执行录制脚本时弹出对话框提示:“iexplore.exe […] 中发生未处理的win32异常” 解决方法: (1)“我的电脑”点右键->属性->高级 点选“性能”中的“设置” (2)打开对话框后,进入“数据执行保护”,如果空白框中没有“Internet Export”,请点击“添加”,选择 c:/program files/internet iexplore/iexplore.exe. 完成设置后,问题解决。
745 0