Проверьте, не работает ли поддержка translate3d при загрузке скрипта в тело

Это предложенное решение, кажется, работает довольно хорошо в большинстве сценариев, но я заметил, что не удается обнаружить поддержку свойств translate3d, когда <script> тег используется внутри <body>,

Воспроизведение онлайн

Эта функция используется для определения поддержки 3d:

function has3d() {
    if (!window.getComputedStyle) {
        return false;
    }

    var el = document.createElement('p'),
        has3d,
        transforms = {
            'webkitTransform':'-webkit-transform',
            'OTransform':'-o-transform',
            'msTransform':'-ms-transform',
            'MozTransform':'-moz-transform',
            'transform':'transform'
        };
    // Add it to the body to get the computed style.
    document.body.insertBefore(el, null);

    for (var t in transforms) {
        if (el.style[t] !== undefined) {
            el.style[t] = "translate3d(1px,1px,1px)";
            has3d = window.getComputedStyle(el).getPropertyValue(transforms[t]);
        }
    }

    document.body.removeChild(el);

    return (has3d !== undefined && has3d.length > 0 && has3d !== "none");
}

0 ответов

Другие вопросы по тегам