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

21,095 Responses

  1. VirgilBlawl表示:

    how to buy clomid without a prescription can i order generic clomid without rx where can i get generic clomid no prescription

  2. El codigo promocional 1xBet 2025: “1XBUM” brinda a los nuevos usuarios un bono del 100% hasta $130. Ademas, el codigo promocional 1xBet de hoy permite acceder a un atractivo bono de bienvenida en la seccion de casino, que ofrece hasta $2275 USD (o su equivalente en VES) junto con 150 giros gratis. Este codigo debe ser ingresado al momento de registrarse en la plataforma para poder disfrutar del bono de bienvenida, ya sea para apuestas deportivas o para el casino de 1xBet. Los nuevos clientes que se registren utilizando el codigo promocional tendran la oportunidad de beneficiarse de la bonificacion del 100% para sus apuestas deportivas.

    codigo promocional de 1xCasino

  3. MbikolkolTef表示:

    Utiliza el codigo de bonificacion de 1xCasino: “1XBUM” para obtener un bono VIP de hasta €1950 mas 150 giros gratis en el casino y un 200% hasta €130 en apuestas deportivas. Introduce nuestro codigo promocional para 1x Casino 2025 en el formulario de registro y reclama bonos exclusivos para el casino y las apuestas deportivas. Bonificacion sin deposito de 1xCasino de $2420. Es necesario registrarse, confirmar tu correo electronico e ingresar el codigo promocional.

    codigo promocional 1xCasino

  4. BrandonJag表示:

    generic zithromax india: can i buy zithromax over the counter in canada – zithromax tablets for sale

  5. BrandonJag表示:

    generic clomid pill: where can i get clomid without prescription – can you get generic clomid tablets

  6. JustinTam表示:

    zithromax for sale us: buy zithromax online with mastercard – zithromax online no prescription

  7. Roberttic表示:

    https://zithropharm.com/# zithromax z-pak

  8. Roberttic表示:

    http://amohealthpharm.com/# buy amoxicillin without prescription

  9. JustinTam表示:

    where can i buy amoxicillin online: AmoHealthPharm – amoxicillin no prescipion

  10. Briantrozy表示:

    can you get cheap clomid without a prescription: ClmHealthPharm – where can i buy cheap clomid without prescription

  11. VirgilBlawl表示:

    zithromax online no prescription Zithro Pharm zithromax tablets for sale

  12. Briantrozy表示:

    buy generic clomid no prescription: ClmHealthPharm – clomid pills

  13. Briantrozy表示:

    doxycycline 50 mg price uk: Dox Health Pharm – generic doxycycline 200 mg

  14. Roberttic表示:

    http://doxhealthpharm.com/# doxycycline 150 mg cost comparison

  15. Roberttic表示:

    http://doxhealthpharm.com/# doxycycline 100mg online uk

  16. I do believe your audience could very well want a good deal more stories like this carry on the excellent hard work.

  17. VirgilBlawl表示:

    cost generic clomid pills ClmHealthPharm get clomid

  18. BrandonJag表示:

    doxycycline online cheap: where can i buy doxycycline no prescription – doxycycline pills cost

  19. JustinTam表示:

    amoxicillin capsules 250mg: amoxicillin tablet 500mg – amoxicillin 500mg buy online uk

  20. BrandonJag表示:

    amoxicillin 500 mg tablet price: Amo Health Pharm – buy amoxicillin

  21. VirgilBlawl表示:

    zithromax z-pak price without insurance zithromax online usa no prescription where can i get zithromax over the counter

  22. It can even seize video at 720p decision.

  23. JustinTam表示:

    doxyhexal: doxycycline 100mg best price – doxycycline 100mg tablet brand name

  24. BrandonJag表示:

    buy clomid pills: cost cheap clomid pills – where can i buy cheap clomid without prescription

  25. The 1xCasino promo code 2025: “1XBUM” welcome bonus is 100% up to €2205 and 75 Free Spins No Deposit Bonus. You need to register, confirm your email and enter bonus code. Register a new account with 1xCasino using the code and enjoy 100 free spins at registration.

    1xcasino bangladesh promo code

  26. Reckchelkokiz表示:

    The 1xCasino promo code 2025: “1XBUM” welcome bonus is 100% up to €2205 and 75 Free Spins No Deposit Bonus. You need to register, confirm your email and enter bonus code. Register a new account with 1xCasino using the code and enjoy 100 free spins at registration.

    1xcasino free promo code today

  27. BrandonJag表示:

    zithromax online paypal: zithromax for sale us – generic zithromax over the counter

  28. Roberttic表示:

    http://zithropharm.com/# zithromax z-pak price without insurance

  29. Roberttic表示:

    https://amohealthpharm.shop/# where can i get amoxicillin 500 mg

  30. JustinTam表示:

    amoxicillin tablets in india: AmoHealthPharm – amoxicillin 250 mg

發佈留言

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