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

  1. Walterclali表示:

    Quincy Anton Promes https://quincy-promes.prostoprosport-br.com Dutch footballer, attacking midfielder and forward for Spartak Moscow . He played for the Dutch national team. He won his first major award in 2017, when Spartak became the champion of Russia.

  2. Lazftl表示:

    order divalproex online cheap – buy aggrenox cheap generic topiramate

  3. Josephton表示:

    The world’s most liveable cities for 2024
    жесток порно видео

    It’s considered among the most beautiful cities in the world to visit, and it seems that Vienna may also be an unbeatable place to live.

    The Austrian city has been crowned the most liveable city in the world yet again in the annual list from the Economist Intelligence Unit (EIU), which was released today.

    The EIU, a sister organization to The Economist, ranked 173 cities across the globe on a number of significant factors, including health care, culture and environment, stability, infrastructure and education.

    Vienna topped the list for the third consecutive year, receiving “perfect” scores in four out of five of the categories — the city was marked lower for culture and environment due to an apparent lack of significant sporting events.
    Just behind the Austrian capital, Denmark’s Copenhagen retained its second place position, while Switzerland’s Zurich moved up from sixth place to third on the list.

    Australia’s Melbourne fell from third to fourth place, while Canadian city Calgary tied for fifth place with Swiss city Geneva.

    Canada’s Vancouver and Australia’s Sydney were in joint seventh place, and Japan’s Osaka and New Zealand’s Auckland rounded out the top 10 in joint ninth place.

  4. 시알리스 구매
    시알리스는 발기 부전(ED) 치료와 관련하여 적절한 사람들에게 처방됩니다. 

  5. Peterkef表示:

    Mohammed Khalil Ibrahim Al-Owais https://mohammed-alowais.prostoprosport-ar.com is a Saudi professional footballer who plays as a goalkeeper for the national team Saudi Arabia and Al-Hilal. He is known for his quick reflexes and alertness at the gate.

  6. GeorgeHib表示:

    Kevin De Bruyne https://kevin-de-bruyne.prostoprosport-ar.com Belgian footballer, midfielder of the Manchester club City” and the Belgian national team. A graduate of the football clubs “Ghent” and “Genk”. In 2008 he began his adult career, making his debut with Genk.

  7. Our communities really need to deal with this.

  8. Thanks for giving your ideas. I would also like to mention that video games have been ever before evolving. Modern tools and revolutions have aided create realistic and interactive games. These kind of entertainment video games were not actually sensible when the concept was being used. Just like other areas of know-how, video games way too have had to advance by means of many ages. This itself is testimony towards the fast growth of video games.

  9. MiltonWit表示:

    Maria Sharapova https://maria-sharapova.prostoprosport-ar.com Russian tennis player. The former first racket of the world, winner of five Grand Slam singles tournaments from 2004 to 2014, one of ten women in history who has the so-called “career slam”.

  10. I?m impressed, I need to say. Really hardly ever do I encounter a blog that?s each educative and entertaining, and let me tell you, you may have hit the nail on the head. Your idea is excellent; the issue is something that not sufficient individuals are talking intelligently about. I am very comfortable that I stumbled throughout this in my seek for something relating to this.

  11. 비아그라 약국 판매  가격
    비아그라 약국 판매: 저렴한 가격과 양질의 의약품에 대한 궁극적인 자원

  12. 비아그라 자주 먹으면
    정기적인 비아그라 섭취의 놀라운 건강상의 이점

  13. MichaelRal表示:

    Luis Fernando Diaz Marulanda https://luis-diaz.prostoprosport-ar.com Colombian footballer, winger for Liverpool and the Colombian national team . Diaz is a graduate of the Barranquilla club. On April 26, 2016, in a match against Deportivo Pereira, he made his Primera B debut. On January 30, 2022, he signed a contract with the English Liverpool for five years, the transfer amount was 40 million euros.

  14. RobertWag表示:

    Lebron Ramone James https://lebronjames.prostoprosport-ar.com American basketball player who plays the positions of small and power forward. He plays for the NBA team Los Angeles Lakers. Experts recognize him as one of the best basketball players in history, and a number of experts put James in first place. One of the highest paid athletes in the world.

  15. 네이버 아이디 판매
    이미 계정 활성화가 되여 있으므로 직접 로그인하고 이용가능합니다.
    개인, 비지니스 목적으로 홍보 등을 하는데 도움이 됩니다.

  16. Gcauit表示:

    hydrea for sale online – purchase trecator sc for sale purchase methocarbamol pills

  17. CharlesKeymn表示:

    Продажа подземных канализационных ёмкостей https://neseptik.com по выгодным ценам. Ёмкости для канализации подземные объёмом до 200 м3. Металлические накопительные емкости для канализации заказать и купить в Екатеринбурге.

  18. 태국 비아그라 구매
    태국에서 비아그라 구매의 위험과 이점 탐색

  19. ia. These va비아그라 구매luable rare 비아그라 구매collections 비아그라 구매serv

  20. Jamesbib表示:

    Kobe Bean Bryant https://kobebryant.prostoprosport-ar.com is an American basketball player who played in the National Basketball Association for twenty seasons for one team, the Los Angeles Lakers. He played as an attacking defender. He was selected in the first round, 13th overall, by the Charlotte Hornets in the 1996 NBA Draft. He won Olympic gold twice as a member of the US national team.

  21. NolanSef表示:

    Купити ліхтарики https://bailong-police.com.ua оптом та в роздріб, каталог та прайс-лист, характеристики, відгуки, акції та знижки. Купити ліхтарик онлайн з доставкою. Відмінний вибір ліхтарів: налобні, ручні, тактичні, ультрафіолетові, кемпінгові, карманні за вигідними цінами.

  22. 비아그라 먹으면 나타나는 증상
    비아그라 복용 시 나타날 수 있는 증상

  23. 비아그라 먹으면 커지나요?
    비아그라 복용 시 성기 크기에 대한 영향

  24. WilliamNep表示:

    montenegro haus am meer kaufen haus kauf montenegro

  25. WilliamErozy表示:

    Ruben Diogo da Silva Neves https://ruben-neves.prostoprosport-ar.com is a Portuguese footballer who plays as a midfielder for the Saudi Arabian club Al-Hilal and the Portuguese national team. Currently, Ruben Neves plays for the Al-Hilal club wearing number 8. His contract with the Saudi club is valid until the end of June 2026.

  26. CharlesNot表示:

    NGolo Kante https://ngolokante.prostoprosport-ar.com is a French footballer who plays as a defensive midfielder for the Saudi Arabian club Al-Ittihad and the French national team. His debut for the first team took place on May 18, 2012 in a match against Monaco (1:2). In the 2012/13 season, Kante became the main player for Boulogne, which played in Ligue 3.

  27. Justinkap表示:

    Взять займ или кредит
    http://www.matrixplus.ru/statraz28052.htm под проценты, подав заявку на денежный микрозайм для физических лиц. Выбирайте среди 570 лучших предложений займа онлайн. Возьмите микрозайм онлайн или наличными в день обращения. Быстрый поиск и удобное сравнение условий по займам и микрокредитам в МФО.

  28. 네이버 아이디 구매 란?
    네이버 플랫품에서 사용되는 아이디를 구매할 수 있습니다.

  29. 이상적인 남자 크기
    이상적인 남자 크기: 성적 만족을 위한 포괄적인 가이드

發佈留言

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