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

16,823 Responses

  1. вызов нарколога на дом [url=http://www.narkolog-na-dom-krasnodar24.ru]вызов нарколога на дом[/url] .

  2. ClaytonGauct表示:

    india online pharmacy: india pharmacy – reputable indian online pharmacy

  3. нарколог на дом в краснодаре [url=http://narkolog-na-dom-krasnodar22.ru/]нарколог на дом в краснодаре[/url] .

  4. Jamesknowl表示:

    https://canadianpharmacy.win/# canadian pharmacy meds reviews

  5. Brianchoky表示:

    https://canadianpharmacy.win/# onlinecanadianpharmacy

  6. Brianchoky表示:

    http://canadianpharmacy.win/# canadian drug pharmacy

  7. Charlesshice表示:

    в баксы в фортнайте – купить v bucks fortnite, купить код фортнайт

  8. LarryHom表示:

    https://mexicanpharmacy.store/# mexico drug stores pharmacies

  9. RichardAgemo表示:

    1XBET promo code 2025: 1XMAX25 – Use bonus code get for VIP bonuses – up to €19502 + 150 free spins on casino and 100% up to €130 on sportsbook! To get your Free Bet, new customers can register with 1xbet for free, and enter the promo code 1x. Take a look at our site banners for the latest 1xBet promo codes and information about the brand’s 100% first deposit bonus where you live. New players can enjoy an exclusive deposit bonus when they sign up at 1xBet. See our site banners for the latest welcome deals at 1xBet for your region.
    1xbet promo code for free bet

  10. ClaytonGauct表示:

    top 10 online pharmacy in india: best online pharmacy india – online shopping pharmacy india

  11. Jamesknowl表示:

    https://mexicanpharmacy.store/# mexican border pharmacies shipping to usa

  12. Jamesknowl表示:

    https://canadianpharmacy.win/# canada online pharmacy

  13. частного нарколога на дом https://narkolog-na-dom-krasnodar22.ru .

  14. Together with every little thing that appears to be developing throughout this particular subject matter, all your perspectives tend to be quite refreshing. On the other hand, I beg your pardon, but I can not give credence to your entire theory, all be it stimulating none the less. It seems to us that your comments are generally not entirely rationalized and in fact you are your self not really totally convinced of the argument. In any case I did appreciate reading it.

  15. Jamestus表示:

    pharmacies in mexico that ship to usa mexican rx online buying prescription drugs in mexico online

  16. LarryHom表示:

    http://mexicanpharmacy.store/# purple pharmacy mexico price list

  17. LarryHom表示:

    http://mexicanpharmacy.store/# buying prescription drugs in mexico

  18. Jamesknowl表示:

    https://mexicanpharmacy.store/# medicine in mexico pharmacies

  19. ClaytonGauct表示:

    online canadian pharmacy: best online canadian pharmacy – the canadian drugstore

發佈留言

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