JQuery boxy插件在IE中边角图片不显示问题的解决


Posted in Javascript onMay 20, 2015

JQuery boxy插件很好用,但也会出现一些问题,比如弹出框的边角在IE中不能显示。本博文将来解决这个问题。将boxy插件引用到项目中后会有一个boxy.css文件和jquery.boxy.js文件。在boxy.css文件中有给弹出框设置四个角图片的样式,如下图:

JQuery boxy插件在IE中边角图片不显示问题的解决

不做任何修改在Chrome浏览器下没有问题,如下:

JQuery boxy插件在IE中边角图片不显示问题的解决

在网上查了一些资料,说将css文件中的图片路径给位全路径可以解决问题,如下:

JQuery boxy插件在IE中边角图片不显示问题的解决

发现这样修改后并没有作用,运行后效果仍然如下:

JQuery boxy插件在IE中边角图片不显示问题的解决

有效的解决方法

将上面css截图的下半部分注释掉,如下图:

JQuery boxy插件在IE中边角图片不显示问题的解决

然后在jquery.boxy.js文件中的Boxy函数中添加一段脚本,下面贴出修改后的Boxy函数代码:

function Boxy(element, options) {
  
  this.boxy = jQuery(Boxy.WRAPPER);
  jQuery.data(this.boxy[0], 'boxy', this);
  
  this.visible = false;
  this.options = jQuery.extend({}, Boxy.DEFAULTS, options || {});
  
  if (this.options.modal) {
    this.options = jQuery.extend(this.options, {center: true, draggable: false});
  }
  
  // options.actuator == DOM element that opened this boxy
  // association will be automatically deleted when this boxy is remove()d
  if (this.options.actuator) {
    jQuery.data(this.options.actuator, 'active.boxy', this);
  }
  
  this.setContent(element || "<div></div>");
  this._setupTitleBar();
  
  this.boxy.css('display', 'none').appendTo(document.body);
  this.toTop();

  if (this.options.fixed) {
    if (jQuery.browser.msie && jQuery.browser.version < 7) {
      this.options.fixed = false; // IE6 doesn't support fixed positioning
    } else {
      this.boxy.addClass('fixed');
    }
  }
  
  if (this.options.center && Boxy._u(this.options.x, this.options.y)) {
    this.center();
  } else {
    this.moveTo(
      Boxy._u(this.options.x) ? this.options.x : Boxy.DEFAULT_X,
      Boxy._u(this.options.y) ? this.options.y : Boxy.DEFAULT_Y
    );
  }

  //fengwei add 2010-11-28
  //用于解决弹出框的圆角在ie中的显示问题
  if ($.browser.msie) {
    var setFilter = function(cls) {
      var obj = $(cls), ret = obj.css("background-image").match(/url\(\"(.+)\"\)/);
      if (ret == null || ret.length < 1) return;
      obj.css({
        "background": "none", "filter": "alpha(opacity=0)",
        "filter": "progid:DXImageTransform.Microsoft.
                       AlphaImageLoader(src='" + ret[1] + "')"
      });
    };

    setFilter(".top-left");
    setFilter(".top-right");
    setFilter(".bottom-left");
    setFilter(".bottom-right");
  }
  
  if (this.options.show) this.show();

};

修改好css和js文件后,再次运行程序,在IE6,7,8中均能正常弹出带边角的框了。

希望本文对您有所帮助。

Javascript 相关文章推荐
用 JavaScript 迁移目录
Dec 18 Javascript
window.open被浏览器拦截后的自定义提示效果代码
Nov 19 Javascript
onmouseover和onmouseout的一些问题思考
Aug 14 Javascript
js计算字符串长度包含的中文是utf8格式
Oct 15 Javascript
jquery渐隐渐显的图片幻灯闪烁切换实现方法
Feb 26 Javascript
JQuery radio(单选按钮)操作方法汇总
Apr 15 Javascript
JavaScript中数据结构与算法(二):队列
Jun 19 Javascript
js跨域请求数据的3种常用的方法
Dec 01 Javascript
js阻止浏览器默认行为的简单实例
May 15 Javascript
Bootstrap表单使用方法详解
Feb 17 Javascript
Vue.js基础学习之class与样式绑定
Mar 20 Javascript
layui 点击重置按钮, select 并没有被重置的解决方法
Sep 03 Javascript
JS中的Replace方法使用经验分享
May 20 #Javascript
jquery使用经验小结
May 20 #Javascript
js实现字符串转日期格式的方法
May 20 #Javascript
JavaScript实现带标题的图片轮播特效
May 20 #Javascript
手机端页面rem宽度自适应脚本
May 20 #Javascript
jquery实现弹出层效果实例
May 19 #Javascript
jQuery结合ajax实现动态加载文本内容
May 19 #Javascript
You might like
不用数据库的多用户文件自由上传投票系统(3)
2006/10/09 PHP
使用PHP提取视频网站页面中的FLASH地址的代码
2010/04/17 PHP
ajax+php控制所有后台函数调用
2015/07/15 PHP
PHP判断FORM表单或URL参数来的数据是否为整数的方法
2016/03/25 PHP
CodeIgniter基于Email类发邮件的方法
2016/03/29 PHP
Laravel框架控制器的request与response用法示例
2019/09/30 PHP
分享14个很酷的jQuery导航菜单插件
2011/04/25 Javascript
seajs1.3.0源码解析之module依赖有序加载
2012/11/07 Javascript
Nodejs极简入门教程(二):定时器
2014/10/25 NodeJs
一个字符串中出现次数最多的字符 统计这个次数【实现代码】
2016/04/29 Javascript
js+html5实现canvas绘制网页时钟的方法
2016/05/21 Javascript
Node.js环境下编写爬虫爬取维基百科内容的实例分享
2016/06/12 Javascript
node.js部署之启动后台运行forever的方法
2018/05/23 Javascript
微信小程序使用canvas的画图操作示例
2019/01/18 Javascript
小程序封装路由文件和路由方法(5种全解析)
2019/05/26 Javascript
jquery实现下载图片功能
2019/07/18 jQuery
JavaScript基于面向对象实现的无缝滚动轮播示例
2020/01/17 Javascript
Python中文分词实现方法(安装pymmseg)
2016/06/14 Python
Python的mysql数据库的更新如何实现
2017/07/31 Python
Python实现的拟合二元一次函数功能示例【基于scipy模块】
2018/05/15 Python
基于Python3.6中的OpenCV实现图片色彩空间的转换
2020/02/03 Python
python如何把字符串类型list转换成list
2020/02/18 Python
Pycharm最常用的快捷键及使用技巧
2020/03/05 Python
python爬取”顶点小说网“《纯阳剑尊》的示例代码
2020/10/16 Python
python 基于UDP协议套接字通信的实现
2021/01/22 Python
HTML5中的新元素介绍
2008/10/17 HTML / CSS
HTML5+css3:3D旋转木马效果相册
2017/01/03 HTML / CSS
澳大利亚儿童精品仓库:Goo & Co.
2019/06/20 全球购物
公司合作意向书
2014/04/01 职场文书
2014年感恩母亲演讲稿
2014/05/27 职场文书
建筑安全生产目标责任书
2014/07/23 职场文书
党员违纪检讨书怎么写
2014/11/01 职场文书
2014年客服工作总结范文
2014/11/13 职场文书
2016年3月份红领巾广播稿
2015/12/21 职场文书
MySQL 表空间碎片的概念及相关问题解决
2021/05/07 MySQL
Python字典的基础操作
2021/11/01 Python