前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ng-options在IE上数据不改变的问题

ng-options在IE上数据不改变的问题

作者头像
javascript.shop
发布2019-09-04 15:57:48
6590
发布2019-09-04 15:57:48
举报
文章被收录于专栏:杰的记事本杰的记事本

最近遇见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,所以解决方案如下:

代码语言:javascript
复制
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);
 
                });
 
            }
 
        }
 
    }
 
]);

使用方式如下:

代码语言:javascript
复制
<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>
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2015年3月20日2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档