JQuery boxy外掛程式在IE中邊角圖片不顯示問題的解決

來源:互聯網
上載者:User

JQuery boxy外掛程式在IE中邊角圖片不顯示問題的解決

   這篇文章主要介紹了JQuery boxy外掛程式在IE中邊角圖片不顯示問題的解決方案,十分的簡單實用,有需要的小夥伴可以參考下。

  JQuery boxy外掛程式很好用,但也會出現一些問題,比如彈出框的邊角在IE中不能顯示。本博文將來解決這個問題。將boxy外掛程式引用到項目中後會有一個boxy.css檔案和jquery.boxy.js檔案。在boxy.css檔案中有給彈出框設定四個角圖片的樣式,如:

  不做任何修改在Chrome瀏覽器下沒有問題,如下:

  在網上查了一些資料,說將css檔案中的圖片路徑給位全路徑可以解決問題,如下:

  發現這樣修改後並沒有作用,運行後效果仍然如下:

  有效解決方案

  將上面css的下半部分注釋掉,如:

  然後在jquery.boxy.js檔案中的Boxy函數中添加一段指令碼,下面貼出修改後的Boxy函數代碼:

  ?

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

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

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中均能正常彈出帶邊角的框了。

  希望本文對您有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.