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

15,025 Responses

  1. The post added a new layer to my understanding of Car Cal ADAS. Thanks for sharing the knowledge.

  2. car cal adas表示:

    Thank you for adding value to the conversation with insights on Car Cal ADAS.

  3. carcal adas表示:

    The writing style on Car Cal ADAS is captivating! I was engaged from start to finish.

  4. RobertMef表示:

    mail order pharmacy india: п»їlegitimate online pharmacies india – indian pharmacy online

  5. Josephfub表示:

    women’s health teva clozapine pharmacy pharmacy rx one discount codes

  6. carcal adas表示:

    This is one of the most comprehensive articles I’ve read on Car Cal ADAS. Kudos!

  7. carcal adas表示:

    The piece was both informative and thought-provoking on Car Cal ADAS. Thanks for the great work!

  8. ArthurKib表示:

    https://mexicopharmacy.cheap/# buying from online mexican pharmacy

  9. MauriceGueda表示:

    best retail pharmacy viagra price: safeway pharmacy store 1818 – xenical singapore pharmacy

  10. The knack for making hard to understand concepts about Car Cal ADAS readable is something I greatly admire.

  11. Arthurjen表示:

    Ретрит http://ретриты.рф международное обозначение времяпрепровождения, посвящённого духовной практике. Ретриты бывают уединённые и коллективные; на коллективных чаще всего проводится обучение практике медитации.

  12. RobertMef表示:

    online pharmacy viagra cialis: pharmacy prices levitra – advair pharmacy price

  13. Coreyges表示:

    Discover the world of excitement at Pin Up Casino, the world’s leading online casino. The official website Pil up offers more than 4,000 slot machines. Play online for real money or for free using the working link today

  14. Coreyges表示:

    Discover the world of excitement at Pin Up Casino, the world’s leading online casino. The official website Puk up offers more than 4,000 slot machines. Play online for real money or for free using the working link today

  15. car cal adas表示:

    I look forward to the posts on Car Cal ADAS because they always offer something valuable. Another great read!

  16. adas car cal表示:

    The unique viewpoints in the writing on Car Cal ADAS never fail to impress me. Insightful as always!

  17. carcal adas表示:

    Breaking down the topic of Car Cal ADAS so clearly was no small feat. Thanks for making it accessible.

  18. This piece was beautifully written and incredibly informative about Car Cal ADAS. Thank you for sharing!

  19. car cal adas表示:

    The post provoked a lot of thought on Car Cal ADAS and taught me something new. Thank you for such engaging content.

  20. The insights on Car Cal ADAS add so much value to the conversation. I always learn something new from you.

  21. car cal adas表示:

    The writing has become a go-to resource for me. The effort you put into the posts on Car Cal ADAS is truly appreciated.

  22. car cal adas表示:

    The piece was both informative and thought-provoking on Car Cal ADAS. Thanks for the great work!

  23. MichaelGed表示:

    Comment puis-je gagner des points промокоды при регистрации на 1хбет?
    Dans le bookmaker 1xbet en tant qu’encouragement des clients pour leur participation active au processus de jeu, ils fournissent des points promotionnels dans le cadre du programme de fidelite. Vous pouvez obtenir des points pour les Paris sportifs reguliers, Express, pour la reconstitution reguliere du compte et la participation aux actions du bookmaker.

  24. ThomasGed表示:

    Le как и куда вводить промокод в 1хбет vous offre un bonus de bienvenue pour une simple inscription allant jusqu’a 130 $. Copiez simplement le code promotionnel et utilisez-le lors de l’inscription. Ceci est la version la plus volumineuse de l’enregistrement, cependant, c’est l’enregistrement complet et ouvre le joueur un acces complet aux fonctionnalites de la plate-forme de jeu.

  25. MauriceGueda表示:

    first medicine online pharmacy store discount code: Benicar – zanax online pharmacy

  26. Josephfub表示:

    reputable indian pharmacies online pharmacy india mail order pharmacy india

  27. Профессиональный сервисный центр по ремонту бытовой техники с выездом на дом.
    Мы предлагаем: сервисные центры в москве
    Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом!

  28. RobertMef表示:

    percocet online pharmacy without prescriptions: rx online – inhouse pharmacy finpecia

  29. VictorTax表示:

    Remember when Lady Gaga ‘bled’ onstage during her shocking performance at the 2009 VMAs?
    смотреть жесткое порно

    Singing about the perils of fame, being dragged out from beneath a fallen chandelier then bleeding to death in front of a roomful of celebrities: Lady Gaga was not shy about making her debut at the MTV Video Music Awards.

    The year was 2009 — many will remember it as the year rapper Ye (formerly Kanye West) stage-crashed 19-year-old Taylor Swift and suggested her award for Best Female Video should have gone to Beyonce instead. But never one to be overshadowed, Lady Gaga, then 23, made some pop culture history of her own that night.

    Her rendition of “Paparazzi” — lamenting both unrequited love and the sinister effects of hounding tabloids — has gone down in the mists of Gaga legend; not least because a lack of high-quality footage means fans must resort to watching grainy screen-recorded versions circulated on social media.
    Over the limited number of pixels, Gaga can be seen at the start of the performance in an all-white ensemble: a bejeweled, asymmetric lace bodysuit and matching cape, thigh-high boots, a feathered Keko Hainswheeler headpiece and strings of glinting pearls. As she staggered back from her piano at the song’s crescendo, however, an audible gasp swept the room as thick blood suddenly appeared to be pouring from her abdomen.

    “I’m your biggest fan, I’ll follow you until you love me,” Gaga wailed desperately, her once-pristine outfit now daubed in scarlet. She ended the number suspended above the stage, ‘dead,’ as more blood dripped from her eyes.

    “(It) gives me chills every time I watch it,” Olivia Rodrigo told MTV in 2021. “I think Lady Gaga is the best performer of our generation.” The “Drivers License” singer appeared to take notes. At this year’s Grammy Awards, she began to ‘bleed’ from clenched fists while performing her hit “vampire,” spreading fake blood across her arms and neck as the song progressed.

  30. ArthurKib表示:

    http://indianpharmacy.company/# Online medicine order

發佈留言

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