踩到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...

28,461 Responses

  1. BillieLet表示:

    pharmacie en ligne sans ordonnance: pharmacies en ligne certifiГ©es – pharmacie en ligne france livraison belgique pharmafst.com

  2. Peterclada表示:

    Cialis generique prix Acheter Cialis 20 mg pas cher cialis generique tadalmed.com

  3. BradleyJaire表示:

    kamagra oral jelly: kamagra en ligne – kamagra pas cher

  4. Prokarniz表示:

    Идеальные жалюзи с пультом для любой комнаты
    жалюзи с пультом жалюзи с пультом . прокарниз

  5. Peterclada表示:

    Kamagra Oral Jelly pas cher Kamagra pharmacie en ligne Kamagra Commander maintenant

  6. BradleyJaire表示:

    pharmacie en ligne livraison europe: Medicaments en ligne livres en 24h – pharmacie en ligne pas cher pharmafst.com

  7. Умные деревянные жалюзи с электроприводом
    Деревянные горизонтальные жалюзи с электроприводом Деревянные горизонтальные жалюзи с электроприводом . +7 (499) 638-25-37

  8. Robertfap表示:

    https://pharmafst.com/# Pharmacie Internationale en ligne

  9. I would also like to mention that most of those who find themselves with no health insurance are typically students, self-employed and those that are laid-off. More than half of those uninsured are under the age of Thirty-five. They do not experience they are wanting health insurance because they’re young and also healthy. The income is often spent on homes, food, and entertainment. Many individuals that do go to work either whole or part time are not presented insurance through their jobs so they get along without due to the rising valuation on health insurance in america. Thanks for the thoughts you write about through this web site.

  10. BillieLet表示:

    acheter mГ©dicament en ligne sans ordonnance: Livraison rapide – Pharmacie en ligne livraison Europe pharmafst.com

  11. Peterclada表示:

    Acheter Kamagra site fiable kamagra 100mg prix kamagra oral jelly

  12. Robertfap表示:

    https://kamagraprix.shop/# Acheter Kamagra site fiable

  13. Bernardshoor表示:

    Achat Cialis en ligne fiable: Tadalafil achat en ligne – Cialis sans ordonnance 24h tadalmed.shop

  14. BradleyJaire表示:

    cialis generique: Cialis sans ordonnance 24h – Acheter Cialis 20 mg pas cher tadalmed.shop

  15. Bernardshoor表示:

    pharmacie en ligne livraison europe: Livraison rapide – acheter mГ©dicament en ligne sans ordonnance pharmafst.com

  16. BillieLet表示:

    pharmacie en ligne france livraison belgique: Livraison rapide – pharmacie en ligne france livraison internationale pharmafst.com

  17. Robertfap表示:

    https://tadalmed.shop/# Cialis en ligne

  18. Peterclada表示:

    pharmacie en ligne france livraison internationale pharmacie en ligne pharmacie en ligne france livraison belgique pharmafst.shop

  19. Robertfap表示:

    http://kamagraprix.com/# kamagra gel

  20. BillieLet表示:

    Cialis sans ordonnance 24h: Cialis sans ordonnance 24h – Cialis en ligne tadalmed.shop

  21. you’re in reality a just right webmaster. The web site loading velocity is incredible. It sort of feels that you’re doing any distinctive trick. In addition, The contents are masterpiece. you’ve performed a great process on this topic!

  22. Robertfap表示:

    https://pharmafst.shop/# Pharmacie sans ordonnance

  23. king88表示:

    Have you given any kind of thought at all with converting your current web-site into French? I know a couple of of translaters here that will would certainly help you do it for no cost if you want to get in touch with me personally.

  24. Облегчите жизнь с жалюзи с пультом — современно и удобно
    жалюзи с пультом жалюзи с пультом . +7 (499) 638-25-37

  25. BillieLet表示:

    Achetez vos kamagra medicaments: Kamagra Commander maintenant – Kamagra Oral Jelly pas cher

  26. BradleyJaire表示:

    Cialis generique prix: Tadalafil sans ordonnance en ligne – Tadalafil achat en ligne tadalmed.shop

發佈回覆給「Robertfap」的留言 取消回覆

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