踩到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,415 Responses

  1. JasonUnsoG表示:

    https://casinositeleri25.com/# deneme bonusu veren casino siteleri

  2. JasonUnsoG表示:

    http://slotsiteleri25.com/# slot siteleri

  3. Lewisgak表示:

    Самые яркие моменты внутренней и внешней политики страны. Заголовки основных событий на Западе, в Европе и мире. «Заголовки дня» https://yapolitical.ru/

  4. Wallacefex表示:

    deneme bonusu veren siteler yeni: yat?r?ms?z deneme bonusu veren siteler – yat?r?ms?z deneme bonusu veren siteler

  5. JasonUnsoG表示:

    http://denemebonusuverensiteler25.com/# denemebonusuverensiteler25

  6. GreggRom表示:

    A brief history of sunglasses, from Ancient Rome to Hollywood
    kraken ссылка

    Sunglasses, or dark glasses, have always guarded against strong sunlight, but is there more to “shades” than we think?

    The pupils of our eyes are delicate and react immediately to strong lights. Protecting them against light — even the brilliance reflected off snow — is important for everyone. Himalayan mountaineers wear goggles for this exact purpose.

    Protection is partly the function of sunglasses. But dark or colored lens glasses have become fashion accessories and personal signature items. Think of the vast and famous collector of sunglasses Elton John, with his pink lensed heart-shaped extravaganzas and many others.

    When did this interest in protecting the eyes begin, and at what point did dark glasses become a social statement as well as physical protection?
    The Roman Emperor Nero is reported as holding polished gemstones to his eyes for sun protection as he watched fighting gladiators.

    We know Canadian far north Copper Inuit and Alaskan Yupik wore snow goggles of many kinds made of antlers or whalebone and with tiny horizontal slits. Wearers looked through these and they were protected against the snow’s brilliant light when hunting. At the same time the very narrow eye holes helped them to focus on their prey.

    In 12th-century China, judges wore sunglasses with smoked quartz lenses to hide their facial expressions — perhaps to retain their dignity or not convey emotions.

  7. Wallacefex表示:

    slot oyunlar?: slot siteleri – en cok kazand?ran slot oyunlar?

  8. Barryanets表示:

    Carrie Underwood slated to perform at Trump’s inauguration
    kraken зеркало
    Country music star Carrie Underwood is slated to perform “America the Beautiful” at President-elect Donald Trump’s inauguration, according to a copy of the program obtained by CNN and confirmed by a spokesperson for the inaugural committee.

    “I love our country and am honored to have been asked to sing at the Inauguration and to be a small part of this historic event,” Underwood said in a statement to CNN. “I am humbled to answer the call at a time when we must all come together in the spirit of unity and looking to the future.”

    The presidential oath of office will be administered by Supreme Court Chief Justice John Roberts with Justice Brett Kavanaugh expected to administer the oath of office to Vice President-elect JD Vance.

    Trump’s inauguration as the 47th president of the United States will take place on January 20 at the US Capitol.

    Underwood is a big get for Trump’s inauguration, considering Hollywood’s Trump blackout over the course of his political career.

    In his first term and throughout the past three elections, Trump has struggled to garner support from major Hollywood stars. At the Republican National Convention last year, the two biggest stars onstage with Trump were musician Kid Rock and retired WWE wrestler Hulk Hogan – a far cry from a superstar at the height of their career, like Underwood.

    The Grammy-winning artist is as high-profile as you can get in country music, not only with numerous platinum hits, but also with public-facing, mainstream business associations. Underwood is the face of Sunday Night Football and is set to make her debut this March as a judge on ABC’s “American Idol” – the singing competition show that catapulted her to fame when she won in 2005.

    While many NFL fans will likely applaud Underwood for singing at the inauguration, any time a celebrity aligns themselves with Trump, they run the risk of alienating left-leaning fans and Hollywood allies.

    Underwood has kept her politics under wraps over the course of her career. In her statement, she did not mention Trump by name and kept her focus on unifying the country – still, Underwood’s decision to publicly align with Trump is a big statement for any star, particularly one as private as the singer.

    Historically, Hollywood has always been closely associated with the Democratic Party, but country stars have always been an outlier, leaning more conservative. In recent years, as new singers join the genre, country music has gotten to be more progressive. This past election cycle, country stars like Mickey Guyton and Maren Morris stood with Vice President Kamala Harris.

  9. BradleyEdino表示:

    yeni deneme bonusu veren siteler deneme bonusu veren yeni siteler denemebonusuverensiteler25

  10. BradleyEdino表示:

    Deneme Bonusu Veren Siteler deneme bonusu veren casino siteleri Deneme Bonusu Veren Siteler

  11. FrankEmine表示:

    sweet bonanza yorumlar: sweet bonanza slot – sweet bonanza kazanma saatleri

  12. FrankEmine表示:

    deneme bonusu veren yeni siteler: yeni deneme bonusu veren siteler – deneme bonusu veren yeni siteler

  13. Timsothyabela表示:

    Pretty component to content. I just stumbled upon your site and in accession capital to say that I acquire in fact enjoyed account your weblog posts. Any way I will be subscribing in your augment or even I success you get entry to constantly quickly.
    https://millionigrushek.ru/

  14. Ok Rechel表示:

    Engaging with The content is like embarking on a treasure hunt, where knowledge is the prize.

  15. Amazed by The knowledge breadth, or what I’ve been mistaking for just good Googling skills.

  16. Wallacefex表示:

    sweet bonanza yorumlar: sweet bonanza guncel – sweet bonanza oyna

  17. BradleyEdino表示:

    slot oyunlar? puf noktalar? en cok kazand?ran slot oyunlar? guvenilir slot siteleri

  18. Tomas Frenner表示:

    I’m so grateful for the information you’ve shared. It’s like receiving a thoughtful gift from someone special.

  19. Each post you write is like a key that unlocks a little more of the world’s mystery.

  20. Beula Cercy表示:

    The ability to convey hard to understand ideas so effortlessly is as attractive as a perfectly tailored suit.

  21. If most people wrote about this subject with the eloquence that you just did, I’m sure people would do much more than just read, they act. Great stuff here. Please keep it up.

  22. JasonUnsoG表示:

    https://casinositeleri25.com/# Casino Siteleri

  23. Each post is a journey, and The words are the map. Thanks for leading the way.

  24. Thank you for the hard work you put into this post. It’s much appreciated!

  25. Hugo Ocampo表示:

    A perfect blend of informative and entertaining, like the ideal date night conversation.

  26. You tackled a hard to understand issue with elegance and insight. I feel much more informed after reading The post.

  27. I’m so grateful for the information you’ve shared. It’s been incredibly enlightening!

  28. BradleyEdino表示:

    deneme bonusu veren siteler yat?r?ms?z deneme bonusu veren siteler yeni deneme bonusu veren siteler

  29. Wallacefex表示:

    Casino Siteleri: deneme bonusu veren casino siteleri – Casino Siteleri

發佈留言

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