0

好的,所以我搜索了一下,找不到我的问题的答案。至少没有一个完全符合我的问题;所以在这里希望你们没有更好的运气,并且你们中的一个人知道我的问题的答案。

在任何人问之前...是的,我是 Microsoft 的开发人员,是的,IE 是我们的产品,是的,我的开发团队中的几乎每个人都宁愿使用 Firefox 或 Chrome 而不是 IE,不...我们无法控制至于它是如何运作的,因为那是 Internet Explorer 团队的责任。此外,我们不是每个人都认为我们是的邪恶帝国。

话虽如此,我会给你我能写出的代码,希望能画出最好的画面。

选择下拉菜单是一个自定义版本,我通过 div 标签隐藏了它的默认箭头,并在它周围的 div 的背景中包含了我自己的下拉箭头,并带有一个类 rightarrow。这些元素通过 jQuery 动态绑定在一起,这里是 jQuery 代码...

function loadMarketSelector(options) {
// If the market selector already exists, just make sure it's visible.
if ($('#marketSelectorContainer').show().length) {
    return;
}

var settings = { defaultCsvMarket: "", marketLabel: "", addUrl: "", loadingId: "", panelId: "", csvMarketOptions: [] };
if (options) {
    $.extend(settings, options);
}

var $select = $('<select>', { id: 'csvMarketSelector', name: 'csvMarketSelector' }).addClass('items');

var defaultCsvMarketLowercase = settings.defaultCsvMarket.toLowerCase();

// Populate the market list
$(settings.csvMarketOptions).each(function (index, element) {
    var $option = $('<option>', { title: element.label, text: element.label, dir: element.dir });
    $option.data('marketId', element.market);
    // If the user hasn't selected a market yet, use the best guess for their current language
    if (element.market.toLowerCase() == defaultCsvMarketLowercase) {
        $option.attr('selected', true);
        $option.attr('class', 'selected');
    } else {
        $option.attr('class', 'other');
    }

    $select.append($option);
});

var $marketSelectorContainer = $('<div class="marketCont" id="marketSelectorContainer">').append($('<div class="marketvalue">').append($('<span>', { text: settings.marketLabel })).append($('<div class="marketlist">').append($('<div class="rightarrow hidden">').append($select))));
$('#payment-options-iframehost').before($marketSelectorContainer);

// When the user clicks on a market, refresh the page with the locale set to that market and with the redemption interface already open
$('.marketlist select').bind({
    change: function () {
        // Reload the page with the language set to the selected market and with the "redeem card" menu already open
        var langParam = "lang=" + $(this).find('option:selected').data('marketId');
        window.location.hash = 'redeem';

        if (!window.location.search) {
            window.location.search = langParam;
        }
        else if (window.location.search.search(/lang=/)) {
            window.location.search = window.location.search.replace(/lang=(.+)&?/, langParam);
        }
        else {
            window.location.search += '&' + langParam;
        }
    },
    click: function(e){
        $(this).parents('.rightarrow').toggleClass('downarrow');

        //Once the select box is clicked collect the options right and left offsets.
        var leftPos = $(this).offset().left;
        var rightPos = leftPos + $(this).width();

        //After the select box is clicked, if the mouse moves outside of the left and right positions;
        //deactivate the dropdown box and return the sprite to it's original position.
        $(document).mousemove(function(e){
            if (e.pageX < leftPos-10 || e.pageX > rightPos+10) {
                $('.marketlist select').trigger('blur');
            }
        })
    },
    blur: function () {
        if ($(this).parent().hasClass('downarrow')) {
            $(this).parent().removeClass('downarrow');
        }
    }
});

var mkt = $('.marketlist select option.selected').data('marketId'),
    iframeId = settings.panelId + " iframe";

if (typeof mkt !== "undefined") {
    // If the market passed to the page (via the lang param or the browser language) is CSV supported, load the PCS iframe
    bam.ui.loadIframe(iframeId, appendParameters(settings.redeemCardUrl, { lmkt: mkt, mkt: mkt }), settings.loadingId, true, function () { $('.rightarrow').show();});
}
else {
    // If the market is not supported, hide the description text but don't load PCS (since it won't work). The selector will be blank by default.
    $(iframeId).hide();
}
}

这是适用于每个元素的 css...

.payment-options-page .marketCont {
    height: 40px;
    margin-left: 50px;
    margin-bottom: 2px;
}
.payment-options-page .marketvalue .marketlist {
    overflow: hidden;
    margin-top:4px;
    text-align: left;
    width: 231px;
    border: 1px solid #7c7c7c;
    display: block;
    vertical-align: middle;
    height: 19px;
    padding-left: 10px;
    line-height: 19px;
    cursor: pointer;
    background: #fff;
}

.payment-options-page .marketvalue .marketlist .rightarrow select
{
    height: 19px;
    background: transparent;
    border: 0;
    border-radius: 0;
    width: 253px;
    position: relative;
    cursor: pointer;
    padding-left: 20px;
    left: -20px;
    z-index: 100001;
}
.payment-options-page .marketlist .rightarrow
{
    background: url('/Content/all/imgs/transactions_down_right_arrow.png') no-repeat;
    background-position: -318px -220px;
    height: 19px;
    width: 180px;
    float: left;
    cursor: pointer;
    padding-left: 10px;
}

.payment-options-page .marketvalue .downarrow {
    background: url('/Content/all/imgs/transactions_down_right_arrow.png') no-repeat;
    background-position: -319px -277px;
    height: 19px;
    float: left;
    cursor: pointer;
    margin-right: 9px;
}

.payment-options-page .marketvalue .marketlist .rightarrow,
.payment-options-page .marketvalue .hover .downarrow 
{
    position:relative;
    overflow:hidden;
}

如果我直接单击选择框,语义选择框在所有浏览器中都可以正常工作。问题是当我单击 IE 中的自定义箭头时,它的作用就像是在下拉列表(即:箭头从右箭头变为向下箭头并且选择框突出显示)(参见 IE 图像)但下拉box 就像隐藏在其他元素后面一样。

其他表单元素位于 iframe 中,而没有国家/地区下拉列表。

单击箭头在Firefox中工作...

在此处输入图像描述

在 Chrome 中工作...

在此处输入图像描述

在 IE 中点击箭头不会

在此处输入图像描述

但是单击选择框本身确实有效...

在此处输入图像描述

4

1 回答 1

0

我现在在几个项目中遇到了同样的问题并且找不到答案,所以我决定让 IE 浏览器使用它们的默认下拉箭头。如果您已经有一个仅限 IE 的样式表(如果没有阅读这篇关于条件样式最佳实践的文章 - http://www.paulirish.com/2008/conditional-stylesheets-vs-css-hacks-answer-neither/)那么您可以只瞄准那里的箭头,并告诉它不要显示:

.payment-options-page .marketlist .rightarrow {display: none;}

结果可能看起来并不完美,但至少可以正常运行。据我所知,其他浏览器忽略了重叠元素,无论出于何种原因,IE 都会注册此元素并且不允许单击工作,并且无法通过偏移任一元素的“z-index”来修复. 编辑 多一点搜索,我找到了一个原因。IE 不支持pointer-events: none- 这是您需要应用到箭头以让浏览器知道它应该被忽略的 css 属性。有关更多信息,请参阅此答案:https ://stackoverflow.com/a/17441921/2539808

我仍在寻找解决这个问题的方法,如果我找到一个既能运行又能保持我们想要的方式的解决方案,我一定会让你知道:)

于 2013-09-04T17:07:46.437 回答