解决JQuery AutoComplete在IE9下出错的问题

JQuery AutoComplete插件在IE9下会因为bgiframe的问题出错

解决方法:

引入新的bgiframe

 

jquery.bgiframe-2.1.2.js:

 

/* ! Copyright (c) 2010 Brandon Aaron (http://brandonaaron.net)
 * Licensed under the MIT License (LICENSE.txt).
 *
 * Version 2.1.2
 
*/

( function($){

$.fn.bgiframe = ($.browser.msie && /msie 6\.0/i.test(navigator.userAgent) ?  function(s) {
    s = $.extend({
        top     : 'auto',  //  auto == .currentStyle.borderTopWidth
        left    : 'auto',  //  auto == .currentStyle.borderLeftWidth
        width   : 'auto',  //  auto == offsetWidth
        height  : 'auto',  //  auto == offsetHeight
        opacity :  true,
        src     : 'javascript:false;'
    }, s);
     var html = '<iframe class="bgiframe"frameborder="0"tabindex="-1"src="'+s.src+'"'+
                   'style="display:block;position:absolute;z-index:-1;'+
                       (s.opacity !==  false?'filter:Alpha(Opacity=\'0\');':'')+
                       'top:'+(s.top=='auto'?'expression(((parseInt(this.parentNode.currentStyle.borderTopWidth)||0)*-1)+\'px\')':prop(s.top))+';'+
                       'left:'+(s.left=='auto'?'expression(((parseInt(this.parentNode.currentStyle.borderLeftWidth)||0)*-1)+\'px\')':prop(s.left))+';'+
                       'width:'+(s.width=='auto'?'expression(this.parentNode.offsetWidth+\'px\')':prop(s.width))+';'+
                       'height:'+(s.height=='auto'?'expression(this.parentNode.offsetHeight+\'px\')':prop(s.height))+';'+
                '"/>';
     return  this.each( function() {
         if ( $( this).children('iframe.bgiframe').length === 0 )
             this.insertBefore( document.createElement(html),  this.firstChild );
    });
} :  function() {  return  this; });

//  old alias
$.fn.bgIframe = $.fn.bgiframe;

function prop(n) {
     return n && n.constructor === Number ? n + 'px' : n;
}

})(jQuery);

 

 

转载于:https://www.cnblogs.com/davidgu/archive/2012/04/27/2473125.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值