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

20,992 Responses

  1. ThomasThype表示:

    Mesin slot digital semakin banyak diminati: slot demo – slot demo rupiah

  2. Williecrady表示:

    Pemain harus menetapkan batas saat bermain http://preman69.tech/# Pemain bisa menikmati slot dari kenyamanan rumah

  3. ThomasThype表示:

    Slot menawarkan berbagai jenis permainan bonus: BonaSlot – BonaSlot

  4. DannyUnded表示:

    How Nigeria’s biggest city became the world’s hottest winter party destination
    casino bonus

    It’s a world of endless parties and sleepless nights. A relentless celebration that turns West Africa – and especially Nigeria’s largest city, Lagos – into one of the hottest destinations on the continent, if not the planet, right in the middle of winter.

    Detty December is a magical time between December and early January when diaspora communities and tourists flock to Ghana, Nigeria and South Africa for an unforgettable experience filled with flavourful food, soulful African music and sunshine.

    Beach parties, festivals and top-tier performances fuel the energy, while fashion takes center stage, with everyone dressing to impress.

    Nearly two-thirds of Nigeria’s population is under 25, according to the United Nations Population Fund, making this one of the world’s youngest countries.

    Internationally renowned Afrobeats performers and foreign artists make surprise appearances. DJs take to the streets, blasting powerful beats from consoles mounted atop bright yellow minibuses.

    At times it’s all-consuming. Good luck getting hair salon appointments, affordable air tickets or navigating Lagos’ already notorious traffic when the party crowds are in town.

    Detty December (“detty” is a playful corruption of “dirty”) is a triumphant celebration of culture, music and good vibes that has evolved in recent years during the traditional holidays influx of diaspora returnees, which heightened in 2018 when Ghana ran a launched a successful “Year of Return” campaign actively encouraging people to visit their ancestral homelands.

    It’s gathered pace over the past five years, gaining an international reputation, as IJGBs (“I Just Got Backs”) and their friends arrive in batches, eager to unwind and blow off steam after the fast-paced, hard-working year they’ve had overseas.

    For many in the vast Nigerian diaspora, it is a deeply personal homecoming, a chance to reconnect with their heritage, traditions and families while immersing themselves in the lively energy of Nigerian life.

  5. DavidCooth表示:

    http://bonaslot.site/# Slot dengan pembayaran tinggi selalu diminati

  6. DavidCooth表示:

    https://garuda888.top/# Mesin slot baru selalu menarik minat

  7. Williecrady表示:

    Kasino selalu memperbarui mesin slotnya https://slot88.company/# Slot dengan fitur interaktif semakin banyak tersedia

  8. Williecrady表示:

    Banyak pemain mencari mesin dengan RTP tinggi http://slot88.company/# Slot menawarkan berbagai jenis permainan bonus

  9. ThomasThype表示:

    Banyak pemain menikmati jackpot harian di slot: preman69.tech – preman69

  10. DavidCooth表示:

    https://slot88.company/# Banyak pemain menikmati bermain slot secara online

  11. ThomasThype表示:

    Slot menawarkan kesenangan yang mudah diakses: slot88.company – slot 88

  12. Williecrady表示:

    Beberapa kasino memiliki area khusus untuk slot https://slotdemo.auction/# Banyak kasino memiliki promosi untuk slot

  13. DavidCooth表示:

    https://slot88.company/# Kasino sering mengadakan turnamen slot menarik

  14. Aaronbus表示:

    bonaslot BonaSlot Banyak kasino menawarkan permainan langsung yang seru

  15. Williecrady表示:

    Pemain harus memahami aturan masing-masing mesin https://slot88.company/# Pemain harus menetapkan batas saat bermain

  16. DavidCooth表示:

    https://bonaslot.site/# Kasino di Bali menarik banyak pengunjung

  17. You actually make it appear so easy together with your presentation however I to find this topic to be actually something which I believe I’d by no means understand. It seems too complicated and extremely large for me. I am having a look ahead in your subsequent submit, I will attempt to get the hang of it!

  18. Williecrady表示:

    Permainan slot mudah dipahami dan menyenangkan https://slot88.company/# Slot menawarkan kesenangan yang mudah diakses

  19. ThomasThype表示:

    Banyak kasino memiliki program loyalitas untuk pemain: garuda888.top – garuda888 slot

  20. ThomasThype表示:

    Mesin slot baru selalu menarik minat: bonaslot.site – bonaslot

  21. DavidCooth表示:

    http://preman69.tech/# Bermain slot bisa menjadi pengalaman sosial

  22. Williecrady表示:

    Pemain harus memahami aturan masing-masing mesin https://bonaslot.site/# Kasino selalu memperbarui mesin slotnya

  23. DavidCooth表示:

    https://slot88.company/# Kasino memastikan keamanan para pemain dengan baik

  24. Hello.This article was extremely interesting, particularly since I was searching for thoughts on this subject last couple of days.

  25. Williecrady表示:

    Slot dengan bonus putaran gratis sangat populer https://preman69.tech/# Mesin slot sering diperbarui dengan game baru

  26. ThomasThype表示:

    Bermain slot bisa menjadi pengalaman sosial: preman69 – preman69 slot

  27. Williecrady表示:

    Mesin slot menawarkan pengalaman bermain yang cepat http://slotdemo.auction/# Kasino di Bali menarik banyak pengunjung

  28. DavidCooth表示:

    http://garuda888.top/# Banyak pemain mencari mesin dengan RTP tinggi

發佈留言

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