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

9,257 Responses

  1. Allenacurf表示:

    pharmacie en ligne: Acheter Cialis – pharmacie en ligne france livraison internationale

  2. RobertBlica表示:

    https://cenligne.com/# pharmacie en ligne france livraison internationale

  3. IgnacioSlima表示:

    trouver un mГ©dicament en pharmacie: kamagra pas cher – pharmacie en ligne france livraison belgique

  4. XRumer23obliz表示:

    Hello!

    This post was created with XRumer 23 StrongAI.

    Good luck 🙂

  5. Allenacurf表示:

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

  6. I’m so grateful for the information you’ve shared. It’s like receiving a thoughtful gift from someone special.

  7. The post touched on things that resonate with me personally. Thank you for putting it into words.

  8. The perspective is incredibly valuable to me. Thanks for opening my eyes to new ideas.

  9. Refreshing take on the subject, like a cold splash of water to my long-held beliefs.

  10. The perspective is like a rare gem, valuable and unique in the vastness of the internet.

  11. Breaking down this topic so clearly was no small feat. Thanks for making it accessible.

  12. I always learn something new from The posts. Thank you for the education!

  13. Compelling read with well-presented arguments. I almost felt persuaded. Almost.

  14. Reading The work is like gazing at a masterpiece; every detail contributes to a breathtaking whole.

  15. RobertBlica表示:

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

  16. KeithKef表示:

    pharmacie en ligne france pas cher levitra generique pharmacie en ligne pas cher

  17. EdwardGROOM表示:

    pharmacie en ligne pas cher: Pharmacies en ligne certifiees – Pharmacie sans ordonnance

  18. EdwardGROOM表示:

    pharmacie en ligne livraison europe: kamagra en ligne – pharmacie en ligne france fiable

  19. 비아그라表示:

    비아그라가 모든 사람에게 효과가 없는 이유: 비효율적인 결과 이면의 요인 이해
    비아그라 효과 없는사람

  20. Allenacurf表示:

    pharmacie en ligne france livraison internationale: cialis prix – pharmacie en ligne avec ordonnance

  21. IgnacioSlima表示:

    pharmacie en ligne livraison europe: Pharmacie en ligne livraison Europe – pharmacie en ligne

  22. EdwardGROOM表示:

    SildГ©nafil 100 mg prix en pharmacie en France: Viagra generique en pharmacie – Viagra femme ou trouver

  23. EdwardGROOM表示:

    pharmacie en ligne fiable: kamagra 100mg prix – pharmacie en ligne france pas cher

  24. Allenacurf表示:

    Pharmacie sans ordonnance: Acheter Cialis 20 mg pas cher – Pharmacie sans ordonnance

  25. Heya are using WordPress for your site platform? I’m new to the blog world but I’m trying to get started and set up my own. Do you require any html coding knowledge to make your own blog? Any help would be really appreciated!

  26. KeithKef表示:

    Viagra homme prix en pharmacie sans ordonnance viagra en ligne Viagra sans ordonnance livraison 48h

  27. EdwardGROOM表示:

    pharmacie en ligne france livraison belgique: pharmacie en ligne sans ordonnance – pharmacie en ligne fiable

  28. Allenacurf表示:

    pharmacie en ligne avec ordonnance: cialis generique – trouver un mГ©dicament en pharmacie

  29. EdwardGROOM表示:

    pharmacies en ligne certifiГ©es: kamagra pas cher – Pharmacie sans ordonnance

  30. Ignacioreura表示:

    pharmacie en ligne: achat kamagra – п»їpharmacie en ligne france

發佈留言

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