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

17,123 Responses

  1. Donaldabula表示:

    Buy Viagra online cheap FastPillsForMen.com Viagra generic over the counter

  2. BrettTIT表示:

    Buy Tadalafil 5mg: Max Pills For Men – Generic Cialis price

  3. Barrybib表示:

    cost of ed meds: fast pills easy – erectile dysfunction medicine online

  4. вызвать наркологическую помощь [url=snatkina.borda.ru/?1-11-0-00000210-000-0-0-1730875403]вызвать наркологическую помощь[/url] .

  5. неотложная наркологическая помощь [url=https://angelladydety.getbb.ru/viewtopic.php?f=44&t=43023/]неотложная наркологическая помощь[/url] .

  6. скорая наркологическая помощь [url=my.forum2.net/viewtopic.php?id=184]скорая наркологическая помощь[/url] .

  7. Barrybib表示:

    Cialis without a doctor prescription: MaxPillsForMen.com – Cialis 20mg price

  8. наркологическая скорая помощь москва http://aqvakr.forum24.ru/?1-7-0-00011604-000-0-0-1730875452 .

  9. наркологическая скорая помощь москва cah.forum24.ru/?1-19-0-00000470-000-0-0-1730875154 .

  10. неотложная наркологическая помощь в москве неотложная наркологическая помощь в москве .

  11. как вызвать наркологическую скорую помощь в москве как вызвать наркологическую скорую помощь в москве .

  12. BrettTIT表示:

    pills for erectile dysfunction online: cheap cialis – buying ed pills online

  13. Donaldabula表示:

    Generic Viagra for sale FastPillsForMen sildenafil 50 mg price

  14. BrettTIT表示:

    Generic Cialis price: buy cialis online – Cialis over the counter

  15. 789bet表示:

    You are one talented writer thank you for the post.

  16. It’s continually awesome when you can not only be informed, but also entertained! I’m sure you had fun writing this article. Regards, Clotilde.

  17. I am lucky that I discovered this website , precisely the right info that I was searching for! .

  18. RogerFaf表示:

    https://maxpillsformen.com/# Cialis over the counter

  19. RogerFaf表示:

    http://maxpillsformen.com/# Tadalafil price

  20. 789bet表示:

    I encountered your site after doing a search for new contesting using Google, and decided to stick around and read more of your articles. Thanks for posting, I have your site bookmarked now.

  21. BrettCrype表示:

    https://victoriamotorsinc.com/ – auto bid master honda lookup by vin
    hummer vin decoder

發佈留言

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