踩到Window resize在Preview print的雷

最近在作案的過程中遇到一個狀況,從Art design那邊拿到的頁面,會在Window resize的時候執行某個Function,本來一切都正常,但測試到Chrome和Firefox預覽列印時發現也會Trigger這個Event,會讓在預覽列印過後的頁面發生問題,所以必須要進行修正,以下是這個案例的說明:

先在測試頁加入以下的程式,發現在預覽列印的時候會Trigger window resize event:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Preview Print Test</title>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
    <script>
        $(window).resize(function() {
            console.log("Window Resize");
        });
    </script>
</head>
<body>
<h1>Window Resize Test</h1>
</body>
</html>
Preview print trigger window resize event
Preview print trigger window resize event

網路上搜尋了一下解決方案,將Script改寫如下,可以順利解決,但不知道是不是最好的方法,如果大家有更好的也別忘了告訴我唷~

openResizeFn();

// Chorme
var print = false;
var mediaQueryList = window.matchMedia('print');
mediaQueryList.addListener(function (mql) {
    if (mql.matches) {
        closeResizeFn();
    } else {
        setTimeout(openResizeFn, 2000);
    }
});

// Firefox
window.onbeforeprint = function () {
    closeResizeFn();
};
window.onafterprint = function () {
    setTimeout(openResizeFn, 2000);
};

// Common Function
function openResizeFn() {
    $(window).on("resize", windowResize);
}

function closeResizeFn() {
    $(window).off("resize", windowResize);
}

function windowResize() {
    console.log("Window Resize");
}

You may also like...

22,970 Responses

  1. Как выбрать платформу, которая не подведет, не обманет и принесет максимум прибыли? Мы проанализировали десятки криптобирж, сравнили их комиссии, безопасность, удобство и поддержку пользователей, чтобы вы могли торговать с уверенностью.
    Сколько вы уже потеряли из-за неправильного выбора биржи? Пора это исправить! Узнайте, какие платформы возглавляют рейтинг в 2025 году и почему именно они стали фаворитами миллионов трейдеров по всему миру. крипто биржи 2025 топ

  2. Тут можно преобрести сейф пожаровзломостойкие купить взломостойкие сейфы купить

  3. Perryzoozy表示:

    pharmacie en ligne sans ordonnance kamagra oral jelly п»їpharmacie en ligne france

  4. Тут можно преобрести купить сейф взломостойкий cейфы взломостойкие

  5. Jacobbep表示:

    Pharmacie sans ordonnance https://kamagrameilleurprix.com/# vente de mГ©dicament en ligne

  6. Keithloump表示:

    перейти на сайт bsme at

  7. Richardprurf表示:

    https://viagrameilleurprix.com/# Viagra sans ordonnance livraison 48h
    trouver un mГ©dicament en pharmacie

  8. Jacobbep表示:

    pharmacie en ligne https://tadalafilmeilleurprix.shop/# pharmacie en ligne france pas cher

  9. A friend of mine advised me to review this site. And yes. it has some useful pieces of info and I enjoyed reading it.

  10. NorbertKep表示:

    pharmacies en ligne certifiГ©es: cialis generique – pharmacie en ligne fiable

  11. Richardprurf表示:

    https://pharmaciemeilleurprix.shop/# pharmacie en ligne france livraison internationale
    pharmacie en ligne avec ordonnance

  12. NorbertKep表示:

    Pharmacie Internationale en ligne: Acheter Cialis – Achat mГ©dicament en ligne fiable

  13. Diplomi_vept表示:

    купить диплом в каспийске prema-diploms.ru .

  14. NorbertKep表示:

    pharmacie en ligne avec ordonnance: kamagra gel – acheter mГ©dicament en ligne sans ordonnance

  15. Diplomi_xqpt表示:

    диплом о высшем образовании недорого с занесением в реестр диплом о высшем образовании недорого с занесением в реестр .

  16. Perryzoozy表示:

    pharmacie en ligne france livraison belgique trouver un mГ©dicament en pharmacie pharmacie en ligne sans ordonnance

  17. This blog post is excellent, probably because of how well the subject was developed. I like some of the comments too though I could prefer we all stay on the subject in order add value to the subject!

  18. Jacobbep表示:

    Pharmacie sans ordonnance https://pharmaciemeilleurprix.shop/# vente de mГ©dicament en ligne

  19. Appreciate you for sharing these kinds of wonderful threads. In addition, the optimal travel as well as medical insurance program can often relieve those issues that come with journeying abroad. The medical emergency can soon become expensive and that’s absolute to quickly impose a financial burden on the family finances. Having in place the perfect travel insurance package deal prior to setting off is well worth the time and effort. Thank you

  20. Richardprurf表示:

    http://kamagrameilleurprix.com/# pharmacie en ligne france livraison internationale
    pharmacie en ligne livraison europe

  21. Richardprurf表示:

    http://pharmaciemeilleurprix.com/# pharmacie en ligne fiable
    pharmacie en ligne livraison europe

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。