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

9,208 Responses

  1. Andrewswots表示:

    Jude Victor William Bellingham https://jude-bellingham.prostoprosport-fr.com English footballer, midfielder of the Spanish club Real Madrid and the England national team. In April 2024, he won the Breakthrough of the Year award from the Laureus World Sports Awards. He became the first football player to receive it.

  2. Hiya, I’m really glad I’ve found this info. Nowadays bloggers publish only about gossips and web and this is actually frustrating. A good website with exciting content, this is what I need. Thanks for keeping this web site, I will be visiting it. Do you do newsletters? Cant find it.

  3. 시알리스 구매
    시알리스(Cialis)는 비아그라와 유사한 성기능개선제로, 남성의 발기부전 치료에 사용되는 약물입니다. 시알리스의 주요 활성 성분은 타닐라필(타닐라필로)이라는 화합물입니다.

  4. 네이버 아이디 판매
    저희는 네이버 아이디 판매 전문 업체입니다.
    우리는 귀사의 요구를 총족시키기 위해 최선을 다하고 있습니다.

  5. DonaldVox表示:

    Laure Boulleau https://laure-boulleau.prostoprosport-fr.com French football player, defender. She started playing football in the Riom team, in 2000 she moved to Isere, and in 2002 to Issigneux. All these teams represented the Auvergne region. In 2003, Bullo joined the Clairefontaine academy and played for the academy team for the first time.

  6. Larrypef表示:

    Son Heung Min https://sonheung-min.prostoprosport-br.com South Korean footballer, striker and captain of the English Premier League club Tottenham Hotspur and the Republic of Korea national team. In 2022 he won the Premier League Golden Boot. Became the first Asian footballer in history to score 100 goals in the Premier League

  7. 네이버 아이디 판매
    저희는 네이버 아이디 판매 전문 업체입니다.
    우리는 귀사의 요구를 총족시키기 위해 최선을 다하고 있습니다.

  8. 제약업계에서 화이자만큼 인지도와 성공을 거둔 이름은 거의 없습니다. 19세기 중반으로 거슬러 올라가는 역사를 가진 이 다국적 제약 회사는 업계의 강자가 되었습니다.
    화이자 비아그라

  9. RodneyKip表示:

    Kyle Andrew Walker https://kylewalker.prostoprosport-br.com English footballer, captain of the Manchester City club and the England national team. In the 2013/14 season, he was on loan at the Notts County club, playing in League One (3rd division of England). Played 37 games and scored 5 goals in the championship.

  10. JeffreyDem表示:

    Jack Peter Grealish https://jackgrealish.prostoprosport-br.com English footballer, midfielder of the Manchester City club and the England national team. A graduate of the English club Aston Villa from Birmingham. In the 2012/13 season he won the NextGen Series international tournament, playing for the Aston Villa under-19 team

  11. 제약업계에서 화이자만큼 인지도와 성공을 거둔 이름은 거의 없습니다. 19세기 중반으로 거슬러 올라가는 역사를 가진 이 다국적 제약 회사는 업계의 강자가 되었습니다.
    화이자 비아그라

  12. 술먹고 비아그라 먹으면
    음주 후 비아그라 복용하는 것은 권장되지 않습니다

  13. Jefferysance表示:

    Damian Emiliano Martinez https://emiliano-martinez.prostoprosport-br.com Argentine footballer, goalkeeper of the Aston Villa club and national team Argentina. Champion and best goalkeeper of the 2022 World Cup.

  14. CarlosAcard表示:

    Khvicha Kvaratskhelia https://khvicha-kvaratskhelia.prostoprosport-br.com Georgian footballer, winger for Napoli and captain of the Georgian national team. A graduate of Dynamo Tbilisi. He made his debut for the adult team on September 29, 2017 in the Georgian championship match against Kolkheti-1913. In total, in the 2017 season he played 4 matches and scored 1 goal in the championship.

  15. оборудование актового зала оборудование актового зала .

  16. 네이버 아이디 판매
    저희는 네이버 아이디 판매 전문 업체입니다.
    우리는 귀사의 요구를 총족시키기 위해 최선을 다하고 있습니다.

  17. Phillipspult表示:

    Roberto Firmino Barbosa de Oliveira https://roberto-firmino.prostoprosport-br.com Brazilian footballer, attacking midfielder, forward for the Saudi club “Al-Ahli”. Firmino is a graduate of the Brazilian club KRB, from where he moved to Figueirense in 2007. In June 2015 he moved to Liverpool for 41 million euros.

  18. Shawntriek表示:

    Larry Joe Bird https://larry-bird.prostoprosport-br.com American basketball player who spent his entire professional career in the NBA ” Boston Celtics.” Olympic champion (1992), champion of the 1977 Universiade, 3-time NBA champion (1981, 1984, 1986), three times recognized as MVP of the season in the NBA (1984, 1985, 1986), 10 times included in the symbolic teams of the season (1980-88 – first team, 1990 – second team).

  19. Shedding light on this subject like you’re the only star in my night sky. The brilliance is refreshing.

  20. 비아그라 자주 먹으면
    비아그라 자주 복용: 주의할 점과 효과에 대한 이해

  21. 비아그라 복용법
    비아그라를 복용할 때는 의사의 처방을 따르고 제품 정보에 나와 있는 지침을 엄격하게 준수해야 합니다. 일반적인 비아그라 복용법은 다음과 같습니다

  22. RWC Melbourne表示:

    Usually I do not read article on blogs, but I wish to say that this write-up very pressured me to try and do so! Your writing taste has been surprised me. Thank you, quite nice article.

  23. Gustavosar表示:

    Экспертиза ремонта в квартире https://remnovostroi.ru проводится для оценки качества выполненных работ, соответствия требованиям безопасности и стандартам строительства. Специалисты проверяют используемые материалы, исполнение работ, конструктивные особенности, безопасность, внешний вид и эстетику ремонта. По результатам экспертизы составляется экспертное заключение с оценкой качества и рекомендациями по устранению недостатков.

發佈留言

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