Javascript-форум (https://javascript.ru/forum/)
-   Javascript под браузер (https://javascript.ru/forum/css-html/)
-   -   Чем заменить getBoundingClientRect на iPhone Mobile Safari? (https://javascript.ru/forum/css-html/82945-chem-zamenit-getboundingclientrect-na-iphone-mobile-safari.html)

voraa 11.08.2021 10:22

giwuf,
А вы можете посмотреть, что выдает document.body.getBoundingClientRect()
в Сафари? Например, алертом.

giwuf 24.08.2021 17:17

Цитата:

Сообщение от voraa (Сообщение 539334)
giwuf,
А вы можете посмотреть, что выдает document.body.getBoundingClientRect()
в Сафари? Например, алертом.

Сработало при использовании полифила
// polyfilled smooth scrolling for IE, Edge & Safari
const smoothScrollTo = (to, duration) => {
  const element = document.scrollingElement || document.documentElement,
    start = element.scrollTop,
    change = to - start,
    startDate = +new Date();

  // t = current time
  // b = start value
  // c = change in value
  // d = duration
  const easeInOutQuad = (t, b, c, d) => {
    t /= d / 2;
    if (t < 1) return c / 2 * t * t + b;
    t--;
    return -c / 2 * (t * (t - 2) - 1) + b;
  };

  const animateScroll = _ => {
    const currentDate = +new Date();
    const currentTime = currentDate - startDate;
    element.scrollTop = parseInt(easeInOutQuad(currentTime, start, change, duration));
    if (currentTime < duration) {
      requestAnimationFrame(animateScroll);
    } else {
      element.scrollTop = to;
    }
  };
  animateScroll();
};


Часовой пояс GMT +3, время: 11:37.