플랫폼 전반에 걸친 HTML 이메일 테스트를 위한 주요 도구 및 지침

플랫폼 전반에 걸친 HTML 이메일 테스트를 위한 주요 도구 및 지침
플랫폼 전반에 걸친 HTML 이메일 테스트를 위한 주요 도구 및 지침

이메일 클라이언트 전체에서 HTML 이메일 렌더링 최적화

이메일 캠페인을 보냈는데 한 받은 편지함에서는 완벽해 보였지만 다른 받은 편지함에서는 완전히 깨졌음을 발견한 적이 있습니까? 당신은 혼자가 아닙니다. 이메일이 렌더링되는 방식은 Gmail, Outlook 또는 Yahoo Mail과 같은 플랫폼에 따라 크게 다를 수 있으므로 마케팅 담당자와 개발자 모두에게 어려운 과제가 됩니다. 🚀

HTML 이메일 테스트와 관련하여 즉각적인 피드백 도구에 대한 수요가 높습니다. 디자인을 서비스에 제출한 후 결과를 기다리면 워크플로가 중단되고 출시가 지연될 수 있습니다. 이로 인해 많은 사람들이 자신의 설계를 평가하기 위해 더 빠르고 접근하기 쉬운 솔루션을 찾게 되었습니다.

일반적인 문제 중 하나는 MS Word를 사용하여 이메일을 렌더링하는 Outlook 2007과 같은 이전 플랫폼과의 호환성을 보장하는 것입니다. 고급 CSS 기술이 의도한 대로 작동하지 않을 수 있으므로 디자이너에게는 이는 고유한 과제를 제시합니다. 이러한 문제를 해결하려면 신뢰할 수 있는 도구를 찾는 것이 중요합니다.

이 기사에서는 즉각적인 결과를 제공하는 도구에 중점을 두고 HTML 이메일을 테스트하기 위한 최고의 도구 중 일부를 살펴보겠습니다. 또한 모바일 앱부터 데스크톱 받은 편지함에 이르기까지 어디에서나 멋지게 보이는 이메일을 만드는 데 도움이 되는 HTML 이메일 디자인 지침을 공유할 것입니다. 🌟

명령 사용예
document.createElement 이 명령은 HTML 요소를 동적으로 생성합니다. 예를 들어, 첫 번째 스크립트에서는 이메일 레이아웃을 미리 보기 위해 iframe을 생성하는 데 document.createElement('iframe')가 사용되었습니다.
iframe.contentWindow.document iframe 내의 콘텐츠를 직접 조작할 수 있습니다. 예제에서 iframe.contentWindow.document.open()은 HTML 이메일 미리보기를 작성하기 위해 문서를 초기화합니다.
render_template_string 원시 문자열을 HTML 템플릿으로 렌더링하는 Flask 관련 함수입니다. 별도의 HTML 파일 없이 이메일 콘텐츠를 제공하기 위해 Python 백엔드 스크립트에서 사용됩니다.
@app.route Flask 애플리케이션에서 경로를 정의합니다. 백엔드 스크립트에서 @app.route("/")는 이메일 디자인을 미리 볼 수 있도록 엔드포인트를 설정합니다.
fs.readFileSync 파일의 내용을 동기적으로 읽는 Node.js 메서드입니다. 테스트 스크립트에서는 검증을 위해 이메일 템플릿을 로드합니다.
assert Node.js 단위 테스트에서 어설션을 수행하는 데 사용됩니다. 예를 들어, 주장(emailTemplate.includes(''))은 이메일에 제목 태그가 있는지 확인합니다.</td> </tr> <tr> <td>describe</td> <td>Node.js의 Mocha 테스트 프레임워크의 일부입니다. 이메일의 HTML 구조를 검증하는 것과 같은 관련 테스트를 그룹화합니다.</td> </tr> <tr> <td>it</td> <td>Mocha 프레임워크에서 개별 테스트 케이스를 정의합니다. 예를 들어, it('유효한 DOCTYPE을 포함해야 합니다')는 DOCTYPE 선언이 올바르게 포함되었는지 확인합니다.</td> </tr> <tr> <td>emailTemplate.includes</td> <td>이메일 템플릿 내에 특정 문자열이 존재하는지 확인합니다. 이 방법을 사용하면 <title>과 같은 필수 HTML 요소가 디자인에 존재하는지 확인할 수 있습니다.</td> </tr> <tr> <td>iframe.style</td> <td>iframe 요소에 CSS 스타일을 직접 적용합니다. 첫 번째 스크립트에서 iframe.style.width = "100%"는 미리보기가 컨테이너 너비에 맞게 조정되도록 합니다.</td> </tr></table><h3 id="dev1">HTML 이메일 테스트 스크립트가 작업 흐름을 단순화하는 방법</h3><div class="bordersh3"></div><p>HTML 이메일 테스트는 특히 Outlook 2007 또는 Gmail과 같은 다양한 이메일 클라이언트의 특성을 처리할 때 어려운 프로세스가 될 수 있습니다. 위에서 생성된 스크립트는 다양한 환경에 맞는 맞춤형 솔루션을 제공하여 이를 간소화하는 것을 목표로 합니다. 예를 들어 프런트 엔드 스크립트는 이메일 템플릿을 iframe에 삽입하여 동적으로 미리 봅니다. 이 접근 방식은 즉각적인 시각적 피드백을 제공하므로 설계 중 빠른 반복에 이상적입니다. 개발자는 더 이상 이메일 캠페인을 배포하거나 레이아웃이 올바르게 정렬되었는지 확인하기 위해 느린 테스트 서비스를 사용할 필요가 없습니다. 🌟</p><p>반면에 백엔드 Python 스크립트는 통제된 환경에서 이메일 디자인을 제공하고 검증하려는 사람들에게 적합합니다. 플라스크 사용하기 <b>render_template_string</b>, 스크립트는 별도의 파일이 필요 없이 HTML을 직접 렌더링하므로 경량 솔루션이 됩니다. 이는 이메일 템플릿을 사용하는 서버 또는 도구의 호환성 문제를 디버깅하는 데 특히 유용합니다. 예를 들어 마케팅 팀이 웹 엔드포인트에서 제공될 때 디자인이 어떻게 작동하는지 확인하려는 경우 이 스크립트는 격차를 효율적으로 메워줍니다.</p><p>자동화된 검증을 우선시하는 개발자를 위해 Node.js 스크립트는 단위 테스트 기능을 도입합니다. Mocha 프레임워크를 활용하여 스크립트는 DOCTYPE 선언 및 제목 태그와 같은 중요한 구성 요소가 이메일에 있는지 확인합니다. 이는 이메일 클라이언트 렌더링 표준을 준수하는 데 필수적입니다. 회사가 실수로 다음과 같은 메타데이터를 누락한 시나리오를 상상해 보십시오. <b>뷰포트 태그</b>. 단위 테스트는 이메일이 고객에게 도달하기 전에 이러한 감독을 포착하여 시간을 절약하고 당혹스러운 오류를 방지할 수 있습니다. 🚀</p><p>각 스크립트는 모듈식 설계 원칙을 사용하므로 재사용이 가능하고 다양한 워크플로우에 적응할 수 있습니다. 예를 들어 프런트 엔드 스크립트는 HTML용 템플릿 문자열을 사용합니다. 이 문자열은 버튼이나 이미지와 같은 추가 요소를 포함하도록 쉽게 교체하거나 확장할 수 있습니다. 마찬가지로 인증을 포함하도록 백엔드 스크립트를 확장하여 승인된 사용자만 민감한 이메일 캠페인을 미리 볼 수 있도록 할 수 있습니다. 유연성과 특수성을 제공함으로써 이러한 스크립트는 개발자와 마케팅 담당자의 다양한 요구 사항을 해결하는 동시에 생산성을 향상시킵니다.<div id="script0"><h3>프런트엔드 접근 방식을 사용하여 HTML 이메일 렌더링 테스트</h3><div class="bordersh3"></div><p class="langprog">이 솔루션은 브라우저와 유사한 환경에서 HTML 이메일을 즉시 미리 볼 수 있는 재사용 가능한 모듈식 JavaScript 접근 방식을 보여줍니다.</p><pre class="language-javascript"><code>// Create a basic HTML structure for email preview</code> <code>const emailTemplate = `</code> <code> <html></code> <code> <head></code> <code> <style></code> <code> body { font-family: Arial, sans-serif; }</code> <code> .email-container { width: 600px; margin: auto; }</code> <code> </style></code> <code> </head></code> <code> <body></code> <code> <div class="email-container"></code> <code> <h1>Welcome to Our Newsletter!</h1></code> <code> <p>Here is a sample email content.</p></code> <code> </div></code> <code> </body></code> <code> </html>`;</code> <code>// Dynamically inject the email content into an iframe</code> <code>const previewEmail = (template) => {</code> <code> const iframe = document.createElement('iframe');</code> <code> iframe.style.width = "100%";</code> <code> iframe.style.height = "500px";</code> <code> document.body.appendChild(iframe);</code> <code> iframe.contentWindow.document.open();</code> <code> iframe.contentWindow.document.write(template);</code> <code> iframe.contentWindow.document.close();</code> <code>};</code> <code>// Preview the email</code> <code>previewEmail(emailTemplate);</code> </pre></div><div id="script1"><h3>백엔드 접근 방식을 사용하여 HTML 이메일 렌더링 테스트</h3><div class="bordersh3"></div><p class="langprog">이 솔루션은 Python Flask 서버를 활용하여 통제된 환경에서 HTML 이메일을 제공하고 테스트합니다.</p><pre class="language-javascript"><code># Import required modules</code> <code>from flask import Flask, render_template_string</code> <code># Create a Flask app</code> <code>app = Flask(__name__)</code> <code># Define an email template</code> <code>email_template = """</code> <code><html></code> <code><head></code> <code><style></code> <code>body { font-family: Arial, sans-serif; }</code> <code>.email-container { width: 600px; margin: auto; }</code> <code></style></code> <code></head></code> <code><body></code> <code><div class="email-container"></code> <code><h1>Hello from Flask</h1></code> <code><p>This is a test email.</p></code> <code></div></code> <code></body></code> <code></html>"""</code> <code># Route to render the email</code> <code>@app.route("/")</code> <code>def email_preview():</code> <code> return render_template_string(email_template)</code> <code># Run the Flask app</code> <code>if __name__ == "__main__":</code> <code> app.run(debug=True)</code> </pre></div><div id="script2"><h3>단위 테스트를 사용하여 HTML 이메일 렌더링 테스트</h3><div class="bordersh3"></div><p class="langprog">이 솔루션은 Node.js 환경에서 이메일 HTML 렌더링을 확인하기 위한 단위 테스트를 도입합니다.</p><pre class="language-javascript"><code>// Import required modules</code> <code>const fs = require('fs');</code> <code>const assert = require('assert');</code> <code>// Load the email template</code> <code>const emailTemplate = fs.readFileSync('emailTemplate.html', 'utf-8');</code> <code>// Test the structure of the email</code> <code>describe('Email Template Tests', () => {</code> <code> it('should contain a valid DOCTYPE', () => {</code> <code> assert(emailTemplate.includes('<!DOCTYPE html>'), 'DOCTYPE missing');</code> <code> });</code> <code> it('should have a title', () => {</code> <code> assert(emailTemplate.includes('<title>'), 'Title tag missing');</code> <code> });</code> <code> it('should have a container div', () => {</code> <code> assert(emailTemplate.includes('email-container'), 'Container div missing');</code> <code> });</code> <code>});</code> </pre></div></p><h3>원활한 호환성을 위한 HTML 이메일 디자인 마스터하기</h3><div class="bordersh3"></div><p>HTML 이메일 테스트에서 자주 간과되는 측면 중 하나는 다양한 이메일 클라이언트가 어떻게 처리하는지 이해하는 것입니다. <b>CSS 지원</b>. 브라우저와 달리 이메일 클라이언트는 Flexbox 또는 그리드 레이아웃과 같은 최신 CSS와 다양한 수준의 호환성을 갖습니다. 이러한 불일치로 인해 개발자는 테이블 기반 레이아웃과 같은 구식 기술에 의존하게 되는 경우가 많습니다. 예를 들어 Gmail에서는 매끄럽게 보이지만 Outlook 2007에서는 손상되는 이메일을 디자인하는 경우 이러한 미묘한 차이를 아는 것이 중요합니다. 인라인 스타일을 적절하게 사용하면 미적 일관성을 유지하면서 많은 문제를 완화할 수 있습니다. ✨</p><p>또 다른 중요한 고려 사항은 이메일이 모바일 친화적인지 확인하는 것입니다. 40% 이상의 사용자가 모바일 장치에서 이메일을 여는 상황에서 반응형 디자인은 더 이상 선택 사항이 아닙니다. 개발자는 CSS 미디어 쿼리를 사용하여 화면 크기에 따라 레이아웃을 조정할 수 있습니다. MJML 및 Foundation for Emails와 같은 도구는 반응형 이메일 프레임워크를 제공하여 이를 단순화합니다. 예를 들어, 실제 마케팅 캠페인에서는 보다 모바일 친화적인 디자인 전략을 구현함으로써 클릭률이 20% 증가했습니다. 이는 적절한 렌더링이 사용자 참여에 미치는 영향을 강조합니다. 📱</p><p>마지막으로 접근성은 많은 디자이너들이 놓치는 핵심 요소입니다. 이미지에 대한 대체 텍스트를 포함하고, 최소 글꼴 크기를 유지하고, 충분한 명암비를 보장하는 것은 모두 보다 포괄적인 경험을 만드는 것의 일부입니다. 예를 들어 시각 장애가 있는 사용자는 HTML 구조를 해석하는 화면 판독기에 의존할 수 있습니다. VoiceOver 또는 NVDA와 같은 도구를 사용하여 테스트하면 잠재적인 접근성 장벽을 식별하고 개선할 수 있습니다. 이는 모범 사례를 준수할 뿐만 아니라 이메일 도달 범위도 향상시킵니다.</p><div id="newfaq"><div id="adsense-article-faq"></div><h4 id="faq">HTML 이메일 렌더링에 대해 자주 묻는 질문</h4><div class="bordersh4"></div><ol> <li>HTML 이메일 렌더링을 테스트하기 위한 가장 좋은 도구는 무엇입니까?</li> <li>Litmus, Email on Acid 및 MJML과 같은 도구는 여러 이메일 클라이언트에서 즉시 미리보기를 렌더링할 수 있는 강력한 환경을 제공합니다.</li> <li>Outlook 2007/MS Word 렌더링을 구체적으로 테스트하려면 어떻게 해야 합니까?</li> <li>Microsoft Word와 같은 도구를 사용할 수 있습니다. <strong>Virtual Machines</strong> 정확한 테스트를 위해 이전 버전의 Outlook으로 구성되었습니다.</li> <li>이메일의 반응형 디자인을 보장하는 가장 좋은 방법은 무엇입니까?</li> <li>구현하다 <strong>CSS media queries</strong> 사전 구축된 반응형 구성 요소를 제공하는 MJML과 같은 프레임워크도 있습니다.</li> <li>실시간 이메일 서비스 없이 이메일 문제를 어떻게 디버깅합니까?</li> <li>앞서 설명한 Flask 또는 Node.js 솔루션과 같은 로컬 테스트 스크립트를 사용하면 외부 종속성 없이 신속하게 레이아웃을 검증하는 데 도움이 될 수 있습니다.</li> <li>HTML 이메일 디자인에 대한 주요 지침은 무엇입니까?</li> <li>항상 사용 <strong>inline styles</strong>, 접근성 테스트 및 이미지 최적화 <strong>alt text</strong> 보편적인 가독성을 위해.</li> <li>Outlook이 이메일을 다르게 렌더링하는 이유는 무엇입니까?</li> <li>Outlook에서는 <strong>Microsoft Word rendering engine</strong>, 완전한 CSS 지원이 부족하여 최신 HTML 이메일과 불일치가 발생합니다.</li> <li>이메일 HTML 구조를 어떻게 확인할 수 있나요?</li> <li>다음과 같은 도구를 사용하여 검증을 자동화합니다. <strong>Mocha</strong> 다음과 같은 필수 요소를 확인하는 단위 테스트 <strong><title></strong> 또는 <strong><meta></strong> 태그.</li> <li>HTML 이메일 디자인에서 가장 흔한 실수는 무엇입니까?</li> <li>Outlook 2007과 같은 이전 클라이언트에서는 종종 실패하는 고급 CSS에 너무 많이 의존합니다. 인라인 스타일이 더 안전한 접근 방식입니다.</li> <li>더 빠른 로딩을 위해 이메일 이미지를 어떻게 최적화합니까?</li> <li>TinyPNG와 같은 도구를 사용하여 이미지를 압축하고 <strong><img></strong> 렌더링 지연을 방지하기 위한 태그입니다.</li> <li>이메일 접근성을 높이려면 어떻게 해야 합니까?</li> <li>설명을 사용하세요 <strong>alt text</strong>, 높은 명암비를 보장하고 화면 판독기로 테스트하여 접근성 격차를 식별합니다.</li></ol></div><div id="summary"><h4>원활한 호환성을 위해 모든 것을 하나로 모으기</h4><div class="bordersh4"></div><p>청중에게 효과적으로 다가갈 수 있는 세련되고 전문적인 디자인을 만들기 위해서는 클라이언트 전체에서 HTML 렌더링을 테스트하는 것이 필수적입니다. 동적 도구, 자동화된 스크립트, 반응형 프레임워크 등 무엇을 사용하든 올바른 방법을 사용하면 프로세스를 단순화하고 호환성을 보장할 수 있습니다.</p><p>반응형 방식을 수용하고 접근성을 최적화하는 것은 단지 기술적 요구사항이 아니라 사용자 참여를 향상시킵니다. 이러한 솔루션을 활용하면 사용자가 어디에서 열든 공감할 수 있는 디자인을 만들어 장기적인 성공을 보장할 수 있습니다. 🌟</p><div id="source"> <h6>HTML 이메일 렌더링 통찰력에 대한 참조</h6> <div class="bordersh2"></div> <ol> <li>HTML 이메일 테스트 도구 및 렌더링 문제에 대한 정보는 다음에서 출처되었습니다. <a href="https://litmus.com/blog" target="_blank">리트머스 블로그</a> , 이메일 디자인 및 테스트를 위한 포괄적인 리소스입니다.</li> <li>CSS 지원 및 접근성에 대한 지침은 다음에서 참조되었습니다. <a href="https://www.emailonacid.com/blog/" target="_blank">산성에 대한 이메일</a> , 이메일 클라이언트 동작에 대한 자세한 통찰력을 제공합니다.</li> <li>이메일에 대한 반응형 디자인 프레임워크는 다음을 통해 탐색되었습니다. <a href="https://mjml.io/" target="_blank">MJML 문서</a> , 반응형 이메일 템플릿 구축을 위한 선도적인 플랫폼입니다.</li> <li>Outlook 관련 렌더링에 대한 정보는 다음에서 수집되었습니다. <a href="https://support.microsoft.com" target="_blank">마이크로소프트 지원</a> , Word 렌더링 엔진의 미묘한 차이를 자세히 설명합니다.</li> </ol></div></div> </article> </div> <!-- WIDGET RIGHT SIDE SCREEN --> <div id="article-right" class="col-lg-3 ol-md-12 col-sm-12 col-xs-12"> <aside aria-label="sidebar" id="article-sidebar" class="sidebar sidebar-right"> <div id="adsense-right" class="widget sidebaritem d-none d-md-none d-lg-block adsense-right-vertical-div" page="0"> <!-- <script async src="https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client=ca-pub-3922865260272328" crossorigin="anonymous"></script> <ins class="adsbygoogle adsense-right-vertical" style="" data-ad-client="ca-pub-3922865260272328" data-ad-slot="9756184449"></ins> <script> (adsbygoogle = window.adsbygoogle || []).push({}); </script> --> </div> <div id="tempmail-slogan" class="widget w-about widget-sidebar sidebaritem" style="z-index:4;position:relative;background-color: white;margin-top:-30px;"> <div class="widget-title">Tempmail.us.com</div> <div class="bordersh4"></div> <p id="promotext">인터넷에서 가장 성능이 좋은 익명 임시 메일을 찾고 계십니까? 우리의 무료 임시 이메일 서비스는 가장 완벽한 이메일 수신 및 전송, 즐겨찾는 이메일에 대한 리디렉션 생성입니다. 비밀번호를 유지하고 임시 이메일을 평생 사용하세요. POP3, IMAP, SMTP가 무료로 제공됩니다.</p> <div style="width:100%;text-align:right;"> <a class="read-more--with-arrow" href="https://www.tempmail.us.com/ko/"> Temp mail </a> </div> </div> <div id="adsense-article-square"></div> <div id="blog-ajax" style="margin-top:5px;"></div> </aside> </div> </div> </div> </section> <!-- Footer --> <svg width="100%" height="4px" xmlns="http://www.w3.org/2000/svg" class="border-footer"> <defs> <linearGradient id="grad1" x1="0%" y1="0%" x2="100%" y2="0%"> <stop offset="0%" style="stop-color:#EB177D;stop-opacity:1" /> <stop offset="25%" style="stop-color:#F9A933;stop-opacity:1" /> <stop offset="50%" style="stop-color:#3BC7EB;stop-opacity:1" /> <stop offset="75%" style="stop-color:#28C182;stop-opacity:1" /> </linearGradient> </defs> <rect width="100%" height="5px" fill="url(#grad1)" /> </svg> <!-- Balise div pour stocker le numéro de page initial --> <div id="content"> <!-- Contenu de votre page principale --> <div id="page_count"></div> </div> </div> <div class="footer-ad"> <div id="google_ads_iframe" style="max-width:1200px;text-align:center;margin: 0 auto; z-index:5;background-size: cover;background-repeat: no-repeat;background-image: url();"> </div> </div> <!-- ... end Footer --> <div id="javascript-mobile"></div> <script> // Fonction pour charger le script Hotjar function loadHotjar() { (function(h,o,t,j,a,r){ h.hj=h.hj||function(){(h.hj.q=h.hj.q||[]).push(arguments)}; h._hjSettings={hjid:5178820,hjsv:6}; a=o.getElementsByTagName('head')[0]; r=o.createElement('script');r.async=1; r.src=t+h._hjSettings.hjid+j+h._hjSettings.hjsv; a.appendChild(r); })(window,document,'https://static.hotjar.com/c/hotjar-','.js?sv='); } // Écouteur d'événements pour la souris et le toucher if (typeof interactionDetected === 'undefined') { let interactionDetected = false; // Déclaration de la variable // Détecter les mouvements de souris sur desktop window.addEventListener('mousemove', function() { if (!interactionDetected) { interactionDetected = true; loadHotjar(); // Charge le script Hotjar } }); // Détecter les interactions tactiles sur mobile window.addEventListener('touchstart', function() { if (!interactionDetected) { interactionDetected = true; loadHotjar(); // Charge le script Hotjar } }); } </script> <script> // Function to load a script and return a Promise that resolves when the script is loaded function loadScript(src) { return new Promise((resolve, reject) => { const script = document.createElement('script'); script.src = src; script.onload = () => resolve(); script.onerror = () => reject(new Error(`Failed to load script: ${src}`)); document.getElementById('javascript-mobile').appendChild(script); }); } // Async function to sequentially load scripts with a delay after jQuery async function loadScriptsSequentially() { try { // Load jQuery first await loadScript('https://www.tempmail.us.com/js/jquery.min.js'); // Optional: Verify that jQuery is loaded if (typeof jQuery === 'undefined') { throw new Error('jQuery did not load correctly.'); } // Delay of 500ms after jQuery is loaded //await new Promise(resolve => setTimeout(resolve, 100)); // Load the remaining scripts sequentially await loadScript('https://www.tempmail.us.com/js/lazysizes.min.js'); //await new Promise(resolve => setTimeout(resolve, 100)); //await loadScript('https://www.tempmail.us.com/js/load-bg-and-webp.js'); await loadScript('https://www.tempmail.us.com/js/prism.js'); // All scripts loaded successfully console.log('All scripts loaded successfully.'); // You can now execute any code that depends on the loaded scripts // For example: $(document).ready(function() { console.log('jQuery is ready.'); // Your jQuery-dependent code here }); } catch (error) { console.error(error); } } pageCount = document.querySelectorAll('#content #page_count').length; //console.log('Nombre de pages chargées:', pageCount); // Initiate the script loading based on the window width if (window.innerWidth < 900) { loadScriptsSequentially(); } </script> <script> setTimeout(function() { $(document).ready(function() { //permettre le copier-coller // Sélectionnez tous les éléments <pre> dans le document document.addEventListener('mousemove', function() { const pageCount = document.querySelectorAll('#content #page_count').length; //console.log('Nombre de pages chargées:', pageCount); pageNum = pageCount-1; var preElements = document.querySelectorAll('div[page="'+ pageNum +'"] pre'); // Parcourez chaque élément <pre> preElements.forEach(function(preElement, index) { var preId = "pre" + (index + 1); // ID unique, par exemple : pre1, pre2, pre3, ... // Créez un élément <img> avec un attribut onclick qui appelle copyCode avec l'ID correspondant var img = document.createElement("img"); img.src = "https://www.tempmail.us.com/img/copypaste4.png"; // Remplacez par le chemin de votre image img.alt = "복사 및 붙여 넣기"; img.setAttribute("width", "28.698"); img.setAttribute("height", "35"); img.classList.add("lazyload"); img.setAttribute("onclick", "copyCode('" + preId + "', this)"); // Créez un élément div pour contenir l'image var imgContainer = document.createElement("div"); imgContainer.appendChild(img); imgContainer.classList.add("article-copypaste"); // Ajoutez la classe "article-copypaste" à la div // Insérez le imgContainer avant l'élément <pre> preElement.parentNode.insertBefore(imgContainer, preElement); // Attribuez l'ID à l'élément <pre> preElement.id = preId; }); var count = 1; $('.article-copypaste').each(function() { // Vérifie si la div langprog existe juste au-dessus de chaque div article-copypaste if ($(this).prev('.langprog').length === 0) { // Si elle n'existe pas, créez-la $(this).before('<p class="langprog"><br></p>'); } }); $('div[page="0"] .langprog').each(function() { //console.log("test"); // Créez une nouvelle div var newDiv = $('<div>').text(''); // Ajoutez des classes ou des styles à la nouvelle div si nécessaire newDiv.attr('id', "pre"+count+"-alert"); //newDiv.attr('display', "none"); // Ajoutez la nouvelle div en haut de la div actuelle $(this).prepend(newDiv); count++; }); document.removeEventListener('mousemove', arguments.callee); }); }); }, 1000); //copier les pre & code function copyCode(preId, button) { var pre = document.getElementById(preId); var range = document.createRange(); range.selectNode(pre); // Supprimer les espaces en début de chaque ligne var cleanedText = pre.textContent.replace(/^\s+/gm, ""); // Créer un élément temporaire pour copier le texte nettoyé var temp = document.createElement("textarea"); temp.value = cleanedText; document.body.appendChild(temp); temp.select(); document.execCommand("copy"); document.body.removeChild(temp); button.innerHTML = "Copié !"; setTimeout(function() { button.innerHTML = "Copier"; }, 1000); var boxe = "#"+preId+"-alert"; console.log(boxe); showCopyPaste(boxe,"콘텐츠가 클립보드에 복사되었습니다!","success"); } function showCopyPaste(id,textbox,info) { var message = $('div[page="0"] ' + id); message.text(textbox); message.removeClass(); if (info=="general") { message.addClass('alert alert-secondary'); } if (info=="warning") { message.addClass('alert alert-warning'); } if (info=="danger") { message.addClass('alert alert-danger'); } if (info=="success") { message.addClass('alert alert-success'); } message.fadeIn(); setTimeout(function() { message.fadeOut(); }, 3000); // 2000 millisecondes = 2 secondes } </script> <script> setTimeout(function() { $(document).ready(function () { pageCount = document.querySelectorAll('#content #page_count').length; //console.log('Nombre de pages chargées:', pageCount); pageNum = pageCount-1; if ( pageNum==0) { //console.log("repasser par la "); initPositioning(0); // Initial call for the first page } setTimeout(function() { //parce que le prism est en defer Prism.highlightAll(); }, 500); }); $(document).ready(function () { var ajaxAborted = false; var page = 1; // Numéro de la page actuelle var loading = false; // Pour éviter les chargements multiples en même temps var articlesLoaded = false; function loadMoreArticles(unusedHeight) { if (loading || articlesLoaded) return; // Déclenche la requête AJAX pour charger plus d'articles $.ajax({ url: 'https://www.tempmail.us.com/02blog-ajax.php', // L'URL du script PHP pour charger les articles method: 'POST', data: { action: 'getArticles', lang: 'ko', addQueryCat: "AND catclean='rendering'", page: page, currentid: "127409", unusedHeight: unusedHeight // Utilisez la valeur de hauteur non utilisée ici }, dataType: 'html', beforeSend: function (xhr) { loading = true; if (ajaxAborted) { xhr.abort(); // Annuler la requête } }, success: function (response) { // Insérez les nouveaux articles dans la partie vide de la page if ($(response).find('div').length > 0) { const pageCount = document.querySelectorAll('#content #page_count').length; //console.log('Nombre de pages chargées:', pageCount); pageNum = pageCount-1; // La division en particulier est trouvée, continuez le traitement var parentDiv = $('div[page="' + pageNum + '"]'); var blogAjaxElement = parentDiv.find('#blog-ajax'); blogAjaxElement.append(response); } else { ajaxAborted = true; //console.log("aborded"); } // Incrémente le numéro de page page++; loading = false; articlesLoaded = true; }, error: function (xhr, status, error) { // Gérez les erreurs si nécessaire console.error(error); } }); } // Fonction pour calculer la hauteur non utilisée de manière synchrone function calculateUnusedHeight() { const pageCount = document.querySelectorAll('#content #page_count').length; //console.log('Nombre de pages chargées:', pageCount); pageNum = pageCount-1; var parentDiv = $('div[page="' + pageNum + '"]'); var sidebar = parentDiv.find('#article-right')[0]; var sidebarItems = parentDiv.find('.sidebaritem'); var $page = $('[page="' + pageNum + '"]'); var $article = $page.find('#article'); var $newfaq = $page.find('#newfaq'); var totalfaq = $newfaq.outerHeight(); $page.find('[id^=script]').each(function(index) { totalfaq += $(this).outerHeight(); }); //console.log("total height"+totalfaq ) // Comparer avec la hauteur de #article et ajuster si nécessaire var $article = $page.find('#article'); var realarticleheight = $article.outerHeight() - (totalfaq); var totalHeight = realarticleheight; if (totalfaq>realarticleheight) { totalHeight = totalfaq; } //console.log("test"+totalHeight); var itemsHeight = 0; for (var i = 0; i < sidebarItems.length; i++) { itemsHeight += sidebarItems[i].offsetHeight; } var $article = $page.find('#article'); var unusedHeight = $article.outerHeight() - 1600; //var unusedHeight = (totalHeight+400) - (itemsHeight); return unusedHeight; } // Chargez les premiers articles au chargement de la page if ($(window).width() > 991) { setTimeout(function() { var unusedHeight = calculateUnusedHeight(); //console.log("unUsed"+unusedHeight); loadMoreArticles(unusedHeight); }, 1500); } }); }, 1000); </script> <script> setTimeout(function() { $(document).ready(function() { // Fonction pour vérifier le statut de la publicité AdSense après un délai de 2 secondes setTimeout(function() { $(".adsbygoogle").each(function() { var self = $(this); var adStatus = self.attr("data-ad-status"); //console.log("test"+adStatus); if (adStatus === "unfilled") { removeParentDiv(self); // Appel de la fonction pour manipuler la div parent } }); }, 2000); // Attendre 2 secondes // Fonction pour manipuler la div parent function removeParentDiv(element) { var parentDiv = element.closest('#adsense-right'); if (parentDiv.length > 0) { parentDiv.remove(); // Supprimer la div parent si elle est trouvée } } }); }, 1000); // Écoute de l'événement de mouvement de la souris pour charger le script Google AdSense lorsque l'utilisateur effectue une action document.addEventListener('mousemove', function() { // Chargement du script Google AdSense //chargerScriptGoogleAdsenseVertical(); var script = document.createElement('script'); script.src = 'https://www.googletagmanager.com/gtag/js?id=G-ESDTKX54VK'; script.async = true; // Ajoutez le script à l'en-tête du document document.head.appendChild(script); // Initialisez Google Tag Manager lorsque le script est chargé script.onload = function() { window.dataLayer = window.dataLayer || []; function gtag(){dataLayer.push(arguments);} gtag('js', new Date()); gtag('config', 'G-ESDTKX54VK'); }; chargerScriptGoogleAdsenseSquare(); // Suppression de l'écouteur d'événements après le premier déclenchement pour éviter de charger le script à nouveau document.removeEventListener('mousemove', arguments.callee); }); // Fonction pour charger le script Google AdSense function chargerScriptGoogleAdsenseSquare() { // Créez un élément script var script = document.createElement('script'); script.src = "https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client=ca-pub-3922865260272328"; script.async = true; script.crossOrigin = "anonymous"; // Ajoutez une fonction pour exécuter lorsque le script est chargé script.onload = function() { // Créez un élément ins (bloc de publicité AdSense) var ins = document.createElement('ins'); ins.className = "adsbygoogle adsense-right-square"; ins.style = ""; ins.setAttribute('data-ad-client', 'ca-pub-3922865260272328'); ins.setAttribute('data-ad-slot', '2613927101'); // ins.setAttribute('data-ad-format', 'auto'); // ins.setAttribute('data-full-width-responsive', 'true'); // Ajoutez le bloc de publicité à l'emplacement désiré var parentElement = document.querySelector('div[page="0"] .widget.adsenselink.d-none.d-md-none.d-lg-block'); parentElement.appendChild(ins); // Appelez la fonction push() pour afficher la publicité (adsbygoogle = window.adsbygoogle || []).push({}); // Surveillez les changements de l'attribut data-ad-status de l'élément ins var observer = new MutationObserver(function(mutationsList, observer) { mutationsList.forEach(function(mutation) { if (mutation.attributeName === "data-ad-status") { // Récupérez la valeur de l'attribut data-ad-status var status = ins.getAttribute("data-ad-status"); //console.log("Attribut data-ad-status a changé :", status); // Faites ce que vous devez avec la valeur récupérée if (status != "filled") { $('#adsense-right').remove(); // Appel de la fonction pour manipuler la div parent } } }); }); // Configurez l'observateur pour surveiller les changements d'attribut de l'élément ins observer.observe(ins, { attributes: true }); }; // Ajoutez le script à l'emplacement désiré var parentElement = document.querySelector('div[page="0"] .widget.adsenselink.d-none.d-md-none.d-lg-block'); parentElement.appendChild(script); } function chargerScriptGoogleAdsenseVertical() { // Création de l'élément script var script = document.createElement('script'); script.src = "https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client=ca-pub-3922865260272328"; script.async = true; script.crossOrigin = "anonymous"; // Ajout d'une fonction à exécuter lorsque le script est chargé script.onload = function() { // Création de l'élément ins (bloc de publicité AdSense) var ins = document.createElement('ins'); ins.className = "adsbygoogle adsense-right-vertical"; ins.style = ""; ins.setAttribute('data-ad-client', 'ca-pub-3922865260272328'); ins.setAttribute('data-ad-slot', '9756184449'); // Ajout du bloc de publicité à l'emplacement désiré var parentElement = document.querySelector('div[page="0"] .widget.sidebaritem.d-none.d-md-none.d-lg-block.adsense-right-vertical-div'); parentElement.appendChild(ins); // Appel de la fonction push() pour afficher la publicité (adsbygoogle = window.adsbygoogle || []).push({}); var observer = new MutationObserver(function(mutationsList, observer) { mutationsList.forEach(function(mutation) { if (mutation.attributeName === "data-ad-status") { // Récupérez la valeur de l'attribut data-ad-status var status = ins.getAttribute("data-ad-status"); console.log("Attribut data-ad-status a changé :", status); // Faites ce que vous devez avec la valeur récupérée if (status != "filled") { document.querySelector('div[page="0"] .widget.sidebaritem.d-none.d-md-none.d-lg-block.adsense-right-vertical-div').remove(); // Appel de la fonction pour manipuler la div parent } } }); }); // Configurez l'observateur pour surveiller les changements d'attribut de l'élément ins observer.observe(ins, { attributes: true }); }; // Ajout du script à l'emplacement désiré var parentElement = document.querySelector('div[page="0"] .widget.sidebaritem.d-none.d-md-none.d-lg-block.adsense-right-vertical-div'); parentElement.appendChild(script); } </script> <script> function handleScroll() { var scrollPosition = window.scrollY; // Position de défilement par rapport au haut de la page var targetDiv = document.getElementById('navigation'); // Remplacez 'votre-div' par l'ID de votre div cible // Si la position de défilement est supérieure à 0, ajoutez la classe if (scrollPosition > 0) { targetDiv.classList.add('header--fixed'); // Remplacez 'votre-classe' par le nom de la classe que vous souhaitez ajouter } else { // Sinon, supprimez la classe targetDiv.classList.remove('header--fixed'); } } // Écoutez l'événement de défilement window.addEventListener('scroll', handleScroll); </script> <script> setTimeout(function() { $(document).ready(function () { // Définir une variable globale pour vérifier si la nouvelle page a été chargée let nouvellePageChargee = false; // Fonction pour charger la page suivante function chargerPageSuivante(url) { // Charger le contenu de la page suivante via AJAX ou fetch fetch(url) .then(response => response.text()) .then(data => { // Créer un nouvel élément div pour contenir le contenu HTML const tempDiv = document.createElement('div'); tempDiv.innerHTML = data; var navigationLogoElements = tempDiv.querySelectorAll('.navigation-logo'); // Parcourir tous les éléments trouvés et ajouter un style pour les cacher navigationLogoElements.forEach(function(element) { element.style.display = 'none'; }); var h1ArticleElement = tempDiv.querySelector('#h1article'); // Appliquer le style à l'élément sélectionné if (h1ArticleElement) { h1ArticleElement.style.marginBottom = '46px'; h1ArticleElement.style.marginTop = '0px'; h1ArticleElement.style.marginLeft = '10px'; } var articleheader = tempDiv.querySelector('#article-header'); if (articleheader) { articleheader.style.paddingBottom = '20px'; articleheader.style.paddingTop = '20px'; } var h1header = tempDiv.querySelector('#h1article'); if (h1header) { h1header.style.maxWidth = '70%'; } var screenWidth = window.innerWidth; var imgElement = tempDiv.querySelector('.article-main-img'); if (screenWidth > 900 && imgElement) { imgElement.src = 'https://www.tempmail.us.com/images/4c/4c5fec1c85ab1065ea8c82678d700c92.png/debian%EC%97%90%EC%84%9C-ngrok-%EC%A0%9C%EA%B1%B0-%EB%8B%A8%EA%B3%84%EB%B3%84-%EA%B0%80%EC%9D%B4%EB%93%9C.png'; } var desktoplogo = tempDiv.querySelector('.newlogo-desktop'); if (desktoplogo) { var imgElement = document.createElement("img"); imgElement.className = "lazyload"; imgElement.alt = "Temp mail SuperHeros"; if (window.innerWidth > 900) { imgElement.src = "https://www.tempmail.us.com/images/site/tempmail-superheros.webp"; imgElement.width = 343; imgElement.height = 350; desktoplogo.appendChild(imgElement); } } var adsensearticle = tempDiv.querySelector('#adsense-article'); if (adsensearticle) { var scriptElement = document.createElement('script'); scriptElement.src = "https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client=ca-pub-3922865260272328"; scriptElement.async = true; scriptElement.crossorigin = "anonymous"; var insElement = document.createElement('ins'); insElement.className = "adsbygoogle"; insElement.style.display = "block"; insElement.setAttribute('data-ad-client', 'ca-pub-3922865260272328'); insElement.setAttribute('data-ad-slot', '4326653974'); insElement.setAttribute('style', 'display:inline-block;max-width:100%;width:100%;min-height:140px;max-height:140px;padding-top:10px;padding-bottom:0px;'); // Insertion des éléments dans la div #index-adsense var adsContainer = tempDiv.querySelector('#adsense-article'); // adsContainer.style.border = "2px solid #dfe6ec"; // adsContainer.style.paddingTop = "5px"; //adsContainer.style.marginTop = "5px"; // adsContainer.style.height = "110px"; // adsContainer.style.paddingBottom = "0px"; //adsContainer.style.marginBottom = "5px"; // adsContainer.style.backgroundColor = "#f7f8fa"; // adsContainer.style.borderRadius = "5px"; adsContainer.appendChild(scriptElement); adsContainer.appendChild(insElement); } var adsensearticlefaq = tempDiv.querySelector('#adsense-article-faq'); if (adsensearticlefaq) { var scriptElement = document.createElement('script'); scriptElement.src = "https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client=ca-pub-3922865260272328"; scriptElement.async = true; scriptElement.crossorigin = "anonymous"; var insElement = document.createElement('ins'); insElement.className = "adsbygoogle"; insElement.style.display = "block"; insElement.setAttribute('data-ad-client', 'ca-pub-3922865260272328'); insElement.setAttribute('data-ad-slot', '4326653974'); insElement.setAttribute('style', 'display:inline-block;max-width:100%;width:100%;min-height:140px;max-height:140px;padding-top:10px;padding-bottom:0px;'); // Insertion des éléments dans la div #index-adsense var adsContainer = tempDiv.querySelector('#adsense-article-faq'); // adsContainer.style.border = "2px solid #dfe6ec"; // adsContainer.style.paddingTop = "5px"; //adsContainer.style.marginTop = "5px"; // adsContainer.style.height = "110px"; // adsContainer.style.paddingBottom = "0px"; //adsContainer.style.marginBottom = "5px"; // adsContainer.style.backgroundColor = "#f7f8fa"; // adsContainer.style.borderRadius = "5px"; adsContainer.appendChild(scriptElement); adsContainer.appendChild(insElement); } var adsensearticlefaq = tempDiv.querySelector('#adsense-article-square'); if (adsensearticlefaq) { var scriptElement = document.createElement('script'); scriptElement.src = "https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client=ca-pub-3922865260272328"; scriptElement.async = true; scriptElement.crossorigin = "anonymous"; var insElement = document.createElement('ins'); insElement.className = "adsbygoogle"; insElement.style.display = "block"; insElement.setAttribute('data-ad-client', 'ca-pub-3922865260272328'); insElement.setAttribute('data-ad-slot', '4326653974'); insElement.setAttribute('style', 'display:inline-block;width:100%;height:auto;max-width:100%;min-height:350px;max-height:350px;margin-top:10px;margin-bottom:8px;'); // Insertion des éléments dans la div #index-adsense var adsContainer = tempDiv.querySelector('#adsense-article-square'); // adsContainer.style.border = "2px solid #dfe6ec"; // adsContainer.style.paddingTop = "5px"; //adsContainer.style.marginTop = "5px"; // adsContainer.style.height = "110px"; // adsContainer.style.paddingBottom = "0px"; //adsContainer.style.marginBottom = "5px"; // adsContainer.style.backgroundColor = "#f7f8fa"; // adsContainer.style.borderRadius = "5px"; adsContainer.appendChild(scriptElement); adsContainer.appendChild(insElement); } const pageCount = document.querySelectorAll('#content #page_count').length; //console.log('Nombre de pages chargées:', pageCount); // Récupérer tous les éléments avec l'attribut page=1 dans tempDiv const elementsWithPageAttribute = tempDiv.querySelectorAll('[page="0"]'); // Mettre à jour les attributs de ces éléments avec la valeur de pageCount elementsWithPageAttribute.forEach(element => { element.setAttribute('page', pageCount); }); // Extraire et exécuter les scripts de la nouvelle page const scripts = tempDiv.querySelectorAll('script'); scripts.forEach(script => { if (script.type !== 'application/ld+json') { const newScript = document.createElement('script'); // Modifier le contenu du script pour mettre à jour les sélecteurs let scriptContent = script.textContent; // Vérifier si le script contient 'page="0"' et le remplacer par la nouvelle valeur de pageCount // Si le script a un attribut src, le copier if (script.src) { newScript.src = script.src; } else { // Sinon, copier le contenu du script let scriptContent = script.textContent; // Remplacer toutes les occurrences de 'div[page="0"]' par 'div[page="' + pageCount + '"]' scriptContent = scriptContent.replace(/div\[page="0"\]/g, 'div[page="' + pageCount + '"]'); // Assigner le nouveau contenu au script newScript.textContent = scriptContent; } console.log(newScript) document.body.appendChild(newScript); } }); // Ajouter le contenu de la nouvelle page à la page actuelle document.getElementById('content').appendChild(tempDiv); if (pageCount!=0) { initPositioning(pageCount); (adsbygoogle = window.adsbygoogle || []).push({}); (adsbygoogle = window.adsbygoogle || []).push({}); (adsbygoogle = window.adsbygoogle || []).push({}); } // Compter le nombre de div avec l'ID "page_count" }) .catch(error => { console.error('Erreur lors du chargement de la page suivante:', error); }); } // Événement de défilement de la fenêtre window.addEventListener('scroll', function() { // Vérifier si l'utilisateur a atteint le bas de la page var distanceRestante = document.body.offsetHeight - (window.innerHeight + window.scrollY); // Vérifier si l'utilisateur est près du bas de la page if (!nouvellePageChargee && ($(window).scrollTop() + $(window).height()) >= $(document).height() - 100) { // Mettre à jour l'URL dans la barre d'adresse du navigateur avec l'URL de la page suivante window.history.pushState({}, '', 'https://www.tempmail.us.com/ko/ngrok/debian%EC%97%90%EC%84%9C-ngrok-%EC%A0%9C%EA%B1%B0-%EB%8B%A8%EA%B3%84%EB%B3%84-%EA%B0%80%EC%9D%B4%EB%93%9C'); // Charger la page suivante chargerPageSuivante('https://www.tempmail.us.com/ko/ngrok/debian%EC%97%90%EC%84%9C-ngrok-%EC%A0%9C%EA%B1%B0-%EB%8B%A8%EA%B3%84%EB%B3%84-%EA%B0%80%EC%9D%B4%EB%93%9C'); // Désactiver le gestionnaire d'événements de défilement window.removeEventListener('scroll', arguments.callee); } }); }); }, 1000); </script> <script> setTimeout(function() { $(document).ready(function() { //mobile image top load after pour le page speed var imageLoaded = false; // Pour vérifier si l'image a déjà été chargée $(document).on('touchstart', '*', function(event) { if (!imageLoaded) { var $image = $('#lazyImage'); var imageSrc = $image.data('src'); // Récupère l'URL de l'image depuis data-src // Modifie le src de l'image pour charger l'image $image.attr('src', imageSrc); $image.css('min-width', '109%').css('!important', true); $image.css('height', '250px').css('!important', true); // Marque l'image comme chargée imageLoaded = true; // Optionnel : Désactiver l'écoute de l'événement après chargement pour éviter les appels répétés $(document).off('touchstart'); } }); }); }, 1000); function initPositioning(pageCount) { if ($(window).width() > 1700) { var $page = $('[page="' + pageCount + '"]'); console.log("page count"+pageCount); var $newfaq = $page.find('#newfaq'); if ($newfaq.length) { var topOffset = 75 + $newfaq.outerHeight() - 30; var leftOffset = $newfaq.position().left + 30; //fixed mac issues if ($(window).width()==2072) { leftOffset = $newfaq.position().left + 180; } if ($(window).width()==1792) { leftOffset = $newfaq.position().left + 90; } if ($(window).width()==1728) { leftOffset = $newfaq.position().left + 130; } if ($(window).width()==2030) { leftOffset = $newfaq.position().left + 190; } // Calculer la hauteur totale de #newfaq et des scripts var totalHeight = $newfaq.outerHeight(); console.log("CALCUL LA HAUTEUR DU FAQ TOTALHEIGHT"+totalHeight) var $article = $page.find('#article'); var realarticleheight = $article.outerHeight() - totalHeight; //console.log("REGARDER LA HAUTEUR DE L'ARTICLE SANS FAQ"+realarticleheight) //si ya plus de contenue à droite on update sont height if (totalHeight > realarticleheight) { // $article.css('height', totalHeight + 'px'); } var $summary = $page.find('#summary'); if ($summary.length) { var summaryHeight = $summary.outerHeight(); //console.log("SUMMARY HAUTEUR SI DISPONIBLE "+summaryHeight) } // Réinitialiser topOffset après ajustement de #article topOffset = $newfaq.position().top + $newfaq.outerHeight() - 50; // Positionner les divs script pour chaque page $page.find('[id^=script]').each(function(index) { $(this).css({ 'position': 'absolute', 'top': topOffset + 'px', 'left': leftOffset + 'px' }); topOffset += $(this).outerHeight(); }); var totalHeight = $newfaq.outerHeight(); $page.find('[id^=script]').each(function(index) { if ($(this).css('position') === 'absolute') { totalHeight += $(this).outerHeight(); } }); //console.log("CALCUL LA HAUTEUR DU FAQ + SCRIPT absolute TOTALHEIGHT"+totalHeight) setTimeout(function() { if ($("#source").length) { var source = $page.find('#source'); var sourceHeight = source.outerHeight(); } var realarticleheight = $article.outerHeight(); var totalleft = realarticleheight; var totalright = totalHeight-700; console.log("total left "+totalleft) console.log("total right"+totalright) console.log("summary height"+summaryHeight) console.log("source height"+sourceHeight) if ($("#source").length) { if ((totalleft-totalright)>(summaryHeight+sourceHeight)) { $summary.css({ 'position': 'absolute', 'top': (topOffset-50) + 'px', 'left': leftOffset + 'px', 'max-width': '950px' }); source.css({ 'max-width': '950px' }); if ($(window).width()<2000) { $summary.css({ 'max-width': '750px' }); source.css({ 'max-width': '750px' }); } var newrightheight = topOffset+summaryHeight+550; console.log("new right height"+newrightheight) console.log("totalleft"+totalleft) if (newrightheight>totalleft) { console.log("test") // $article.css('height', newrightheight-500 + 'px'); } } } else { if ((totalleft-totalright)>(summaryHeight)) { $summary.css({ 'position': 'absolute', 'top': (topOffset-50) + 'px', 'left': leftOffset + 'px', 'max-width': '950px' }); if ($(window).width()<2000) { $summary.css({ 'max-width': '750px' }); } var newrightheight = topOffset+summaryHeight+550; console.log("new right height"+newrightheight) console.log("totalleft"+totalleft) if (newrightheight>totalleft) { console.log("test") // $article.css('height', newrightheight-500 + 'px'); } } } }, 1000); //si le summary est disponible et que le totalheight+smuaarry sont plus petit on le déplace a droite //SI LE SUMMARY À DROITE PEUT ETRE MISE À GAUCHE POUR BALANCER LA PAGE /* if ((totalHeight+summaryHeight) < ((realarticleheight-summaryHeight))) { } var $source = $page.find('#source'); if ($(window).width()>2000) { $source.css({ 'position': 'absolute', 'top': (topOffset-50) + 'px', 'left': leftOffset + 'px', 'max-width': '950px' }); } else { $source.css({ 'position': 'absolute', 'top': (topOffset-50) + 'px', 'left': leftOffset + 'px', 'max-width': '750px' }); } */ //------------------------------------------------------------------------ //ON RECALCUL LE CÖTÉ DROITE APRÈS LES MODIFICATION ET ON CONFIRME LE GAUCHE var totalHeight = $newfaq.outerHeight(); $page.find('[id^=script]').each(function(index) { if ($(this).css('position') === 'absolute') { totalHeight += $(this).outerHeight(); } }); if ($summary.length) { totalHeight = totalHeight+$('#summary').outerHeight(); } var elements = []; $page.find('[id^=script]').each(function() { elements.push($(this)); }); // Sort the array by ID in descending order elements.sort(function(a, b) { var aNum = parseInt(a.attr('id').replace('script', '')); var bNum = parseInt(b.attr('id').replace('script', '')); return bNum - aNum; }); //console.log("TOTAL HEIGHT VALUE 1 -> "+totalHeight) var $article = $page.find('#article'); realarticleheight = $article.outerHeight(); //console.log("realarticleheight VALUE 1 -> "+realarticleheight ) //-------------------------------------------------------------------- //-------------------------------------------------------------------- SI LE CÖTÉ DROITE EST PLUS LONG QUE LE CÖTÉ GAUCHE if (totalHeight > realarticleheight) { //console.log("TOTAL HEIGHT + GRAND QUE realarticleheight") var difference = totalHeight - realarticleheight; var lastStaticElement = null; if (difference > 500) { elements.forEach(function(item) { if ((difference - item.outerHeight()) > 0) { // Mark the last element that should be static lastStaticElement = item; item.css({ 'position': 'static', 'top': '', 'left': '' }); } // Update the difference for the next iteration difference -= item.outerHeight(); }); // Apply 'static' only to the last element if it exists if (lastStaticElement) { lastStaticElement.css({ 'position': 'static', 'top': '', 'left': '' }); } } var totalHeight = $newfaq.outerHeight(); $page.find('[id^=script]').each(function(index) { if ($(this).css('position') === 'absolute') { totalHeight += $(this).outerHeight(); } }); var $article = $page.find('#article'); realarticleheight = $article.outerHeight(); var difference = totalHeight - realarticleheight; setTimeout(function() { console.log("difference "+difference); /*if (difference > 500) { $summary.css({ 'position': 'absolute', 'top': topOffset + 'px', 'left': leftOffset + 'px' }); } */ // if (difference > 500) { $summary.css({ 'position': 'static', 'top': '', 'left': '' }); //} console.log("passer par la") var $article = $page.find('#article'); // $article.css('height', '11px'); if ($summary.length) { var summaryHeight = $summary.outerHeight(); if ($summary.css('position') === 'absolute') { totalHeight = totalHeight; // $article.css('height', totalHeight + 'px'); } } //console.log("TOTAL HEIGHT APRÈS DÉPLACEMENT VERS LA DROITE "+totalHeight) var $article = $page.find('#article'); //console.log("ARTICLE HEIGHT APRÈS DÉPLACEMENT VER LA DROITE "+$article.outerHeight()) if (totalHeight>$article.outerHeight()) { // $article.css('height', totalHeight+800 + 'px'); } }, 2000); } //-------------------------------------------------------------------- } } } </script> <script> document.addEventListener("DOMContentLoaded", function() { var imgElement = document.createElement("img"); imgElement.className = "lazyload"; imgElement.alt = "Temp mail SuperHeros"; if (window.innerWidth > 900) { imgElement.src = "https://www.tempmail.us.com/images/site/tempmail-superheros.webp"; imgElement.width = 343; imgElement.height = 350; document.querySelector(".newlogo-desktop").appendChild(imgElement); var img = document.getElementById("article-logo"); if (img) { img.src = "https://www.tempmail.us.com/images/site/logo-95px.webp"; img.width = 95; img.height = 90; } } else { imgElement.src = "https://www.tempmail.us.com/images/site/tempmail-superheros-mobile.webp"; imgElement.width = 147; imgElement.height = 150; document.querySelector(".newlogo").appendChild(imgElement); } }); document.addEventListener("DOMContentLoaded", function() { var imageBackgroundDiv = document.getElementById('image-background'); if (!imageBackgroundDiv) return; // Exit if the div doesn't exist var bg320 = imageBackgroundDiv.getAttribute('data-bg-320'); var bg540 = imageBackgroundDiv.getAttribute('data-bg-540'); var bg768 = imageBackgroundDiv.getAttribute('data-bg-768'); var bg1366 = imageBackgroundDiv.getAttribute('data-bg-1366'); var bg1536 = imageBackgroundDiv.getAttribute('data-bg-1536'); var bg1920 = imageBackgroundDiv.getAttribute('data-bg-1920'); var bg2732 = imageBackgroundDiv.getAttribute('data-bg-2732'); var screenWidth = window.innerWidth; if (screenWidth <= 320) { imageBackgroundDiv.style.backgroundImage = `url(${bg320})`; } else if (screenWidth <= 540) { imageBackgroundDiv.style.backgroundImage = `url(${bg540})`; } else if (screenWidth <= 768) { imageBackgroundDiv.style.backgroundImage = `url(${bg768})`; } else if (screenWidth <= 1366) { imageBackgroundDiv.style.backgroundImage = `url(${bg1366})`; } else if (screenWidth <= 1536) { imageBackgroundDiv.style.backgroundImage = `url(${bg1536})`; } else if (screenWidth <= 1920) { imageBackgroundDiv.style.backgroundImage = `url(${bg1920})`; } else { imageBackgroundDiv.style.backgroundImage = `url(${bg2732})`; } }); </script> <script> document.addEventListener("DOMContentLoaded", function() { var screenWidth = window.innerWidth; var imgElement = document.querySelector('.article-main-img'); if (screenWidth > 900 && imgElement) { imgElement.src = 'https://www.tempmail.us.com/images/cd/cde4ce39b907ff9af66be80de888c823-766px.webp/%ED%94%8C%EB%9E%AB%ED%8F%BC-%EC%A0%84%EB%B0%98%EC%97%90-%EA%B1%B8%EC%B9%9C-html-%EC%9D%B4%EB%A9%94%EC%9D%BC-%ED%85%8C%EC%8A%A4%ED%8A%B8%EB%A5%BC-%EC%9C%84%ED%95%9C-%EC%A3%BC%EC%9A%94-%EB%8F%84%EA%B5%AC-%EB%B0%8F-%EC%A7%80%EC%B9%A8-766px.webp'; } }); </script> <script> function closeAd() { document.querySelector('.footer-ad').style.display = 'none'; // Masque l'ad } // Vérification de l'état de l'annonce setInterval(function() { const adElement = document.querySelector('.footer-ad .adsbygoogle'); // Sélecteur mis à jour if (adElement && adElement.getAttribute('data-ad-status') === 'unfilled') { closeAd(); // Ferme l'annonce si elle est non remplie } }, 500); // Vérifie chaque seconde (1000 ms) </script> <script> document.addEventListener("DOMContentLoaded", function() { document.addEventListener('mousemove', function() { var windowWidth = window.innerWidth; if (windowWidth > 900) { var scriptElement = document.createElement('script'); scriptElement.src = "https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client=ca-pub-3922865260272328"; scriptElement.async = true; scriptElement.crossorigin = "anonymous"; var insElement = document.createElement('ins'); insElement.className = "adsbygoogle"; insElement.style.display = "block"; insElement.setAttribute('data-ad-client', 'ca-pub-3922865260272328'); insElement.setAttribute('data-ad-slot', '4326653974'); insElement.setAttribute('style', 'display:inline-block;max-width:100%;width:100%;min-height:140px;max-height:140px;padding-top:10px;padding-bottom:0px;'); // Insertion des éléments dans la div #index-adsense var adsContainer = document.getElementById("adsense-article"); // adsContainer.style.border = "2px solid #dfe6ec"; // adsContainer.style.paddingTop = "5px"; //adsContainer.style.marginTop = "5px"; // adsContainer.style.height = "110px"; // adsContainer.style.paddingBottom = "0px"; //adsContainer.style.marginBottom = "5px"; // adsContainer.style.backgroundColor = "#f7f8fa"; // adsContainer.style.borderRadius = "5px"; adsContainer.appendChild(scriptElement); adsContainer.appendChild(insElement); (adsbygoogle = window.adsbygoogle || []).push({}); // Création des éléments script et ins var scriptElement = document.createElement('script'); scriptElement.src = "https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client=ca-pub-3922865260272328"; scriptElement.async = true; scriptElement.crossorigin = "anonymous"; var insElement = document.createElement('ins'); insElement.className = "adsbygoogle"; insElement.style.display = "block"; insElement.setAttribute('data-ad-client', 'ca-pub-3922865260272328'); insElement.setAttribute('data-ad-slot', '4395216949'); insElement.setAttribute('style', 'display:block;width:100%;height:auto;max-width:100%;min-height:140px;max-height:140px;margin-top:10px;margin-bottom:8px;'); var adsContainer = document.getElementById("adsense-article-faq"); // adsContainer.style.border = "2px solid #dfe6ec"; // adsContainer.style.paddingTop = "10px"; // adsContainer.style.paddingBottom = "0px"; // adsContainer.style.marginBottom = "10px"; // adsContainer.style.height = "110px"; // adsContainer.style.backgroundColor = "#f7f8fa"; // adsContainer.style.borderRadius = "5px"; if (adsContainer) { adsContainer.appendChild(scriptElement); adsContainer.appendChild(insElement); // Rechargez les annonces pour qu'elles soient affichées correctement (adsbygoogle = window.adsbygoogle || []).push({}); } // Création des éléments script et ins var scriptElement = document.createElement('script'); scriptElement.src = "https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client=ca-pub-3922865260272328"; scriptElement.async = true; scriptElement.crossorigin = "anonymous"; var insElement = document.createElement('ins'); insElement.className = "adsbygoogle"; insElement.style.display = "block"; insElement.setAttribute('data-ad-client', 'ca-pub-3922865260272328'); insElement.setAttribute('data-ad-slot', '4395216949'); insElement.setAttribute('style', 'display:inline-block;width:100%;height:auto;max-width:100%;min-height:350px;max-height:350px;margin-top:10px;margin-bottom:8px;'); var adsContainer = document.getElementById("adsense-article-square"); // adsContainer.style.border = "2px solid #dfe6ec"; // adsContainer.style.paddingTop = "10px"; // adsContainer.style.paddingBottom = "0px"; // adsContainer.style.marginBottom = "10px"; // adsContainer.style.height = "110px"; // adsContainer.style.backgroundColor = "#f7f8fa"; // adsContainer.style.borderRadius = "5px"; if (adsContainer) { adsContainer.appendChild(scriptElement); adsContainer.appendChild(insElement); // Rechargez les annonces pour qu'elles soient affichées correctement (adsbygoogle = window.adsbygoogle || []).push({}); } // Création des éléments script et ins var scriptElement = document.createElement('script'); scriptElement.src = "https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client=ca-pub-3922865260272328"; scriptElement.async = true; scriptElement.crossorigin = "anonymous"; var insElement = document.createElement('ins'); insElement.className = "adsbygoogle"; insElement.style.display = "block"; insElement.setAttribute('data-ad-client', 'ca-pub-3922865260272328'); insElement.setAttribute('data-ad-slot', '9665260777'); insElement.setAttribute('data-ad-format', 'auto'); insElement.setAttribute('data-full-width-responsive', 'true'); var adsContainer = document.getElementById("google_ads_iframe"); adsContainer.style.border = "2px solid #dfe6ec"; adsContainer.style.padding = "10px"; adsContainer.style.marginBottom = "10px"; adsContainer.style.backgroundColor = "#f7f8fa"; adsContainer.style.borderRadius = "5px"; adsContainer.appendChild(scriptElement); adsContainer.appendChild(insElement); // Rechargez les annonces pour qu'elles soient affichées correctement (adsbygoogle = window.adsbygoogle || []).push({}); } document.removeEventListener('mousemove', arguments.callee); }); }); setTimeout(function() { var pubLoaded = false; // Pour vérifier si l'image a déjà été chargée $(document).on('touchstart', '*', function(event) { if (!pubLoaded) { // Marque la pub comme chargée pubLoaded = true; // Optionnel : Désactiver l'écoute de l'événement après chargement pour éviter les appels répétés $(document).off('touchstart'); var windowWidth = window.innerWidth; if (windowWidth < 900) { var scriptElement = document.createElement('script'); scriptElement.src = "https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client=ca-pub-3922865260272328"; scriptElement.async = true; scriptElement.crossorigin = "anonymous"; var insElement = document.createElement('ins'); insElement.className = "adsbygoogle"; insElement.style.display = "block"; insElement.setAttribute('data-ad-client', 'ca-pub-3922865260272328'); insElement.setAttribute('data-ad-slot', '4326653974'); insElement.setAttribute('style', 'display:inline-block;max-width:100%;width:100%;min-height:140px;max-height:140px;padding-top:10px;padding-bottom:0px;'); // Insertion des éléments dans la div #index-adsense var adsContainer = document.getElementById("adsense-article"); // adsContainer.style.border = "2px solid #dfe6ec"; // adsContainer.style.paddingTop = "5px"; //adsContainer.style.marginTop = "5px"; // adsContainer.style.height = "110px"; // adsContainer.style.paddingBottom = "0px"; //adsContainer.style.marginBottom = "5px"; // adsContainer.style.backgroundColor = "#f7f8fa"; // adsContainer.style.borderRadius = "5px"; adsContainer.appendChild(scriptElement); adsContainer.appendChild(insElement); (adsbygoogle = window.adsbygoogle || []).push({}); // Création des éléments script et ins var scriptElement = document.createElement('script'); scriptElement.src = "https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client=ca-pub-3922865260272328"; scriptElement.async = true; scriptElement.crossorigin = "anonymous"; var insElement = document.createElement('ins'); insElement.className = "adsbygoogle"; insElement.style.display = "block"; insElement.setAttribute('data-ad-client', 'ca-pub-3922865260272328'); insElement.setAttribute('data-ad-slot', '4395216949'); insElement.setAttribute('style', 'display:block;width:100%;height:auto;max-width:100%;min-height:140px;max-height:140px;margin-top:10px;margin-bottom:8px;'); var adsContainer = document.getElementById("adsense-article-faq"); // adsContainer.style.border = "2px solid #dfe6ec"; // adsContainer.style.paddingTop = "10px"; // adsContainer.style.paddingBottom = "0px"; // adsContainer.style.marginBottom = "10px"; // adsContainer.style.height = "110px"; // adsContainer.style.backgroundColor = "#f7f8fa"; // adsContainer.style.borderRadius = "5px"; if (adsContainer) { adsContainer.appendChild(scriptElement); adsContainer.appendChild(insElement); // Rechargez les annonces pour qu'elles soient affichées correctement (adsbygoogle = window.adsbygoogle || []).push({}); } // Création des éléments script et ins var scriptElement = document.createElement('script'); scriptElement.src = "https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client=ca-pub-3922865260272328"; scriptElement.async = true; scriptElement.crossorigin = "anonymous"; var insElement = document.createElement('ins'); insElement.className = "adsbygoogle"; insElement.style.display = "block"; insElement.setAttribute('data-ad-client', 'ca-pub-3922865260272328'); insElement.setAttribute('data-ad-slot', '4395216949'); insElement.setAttribute('style', 'display:inline-block;width:100%;height:auto;max-width:100%;min-height:350px;max-height:350px;margin-top:10px;margin-bottom:8px;'); var adsContainer = document.getElementById("adsense-article-square"); // adsContainer.style.border = "2px solid #dfe6ec"; // adsContainer.style.paddingTop = "10px"; // adsContainer.style.paddingBottom = "0px"; // adsContainer.style.marginBottom = "10px"; // adsContainer.style.height = "110px"; // adsContainer.style.backgroundColor = "#f7f8fa"; // adsContainer.style.borderRadius = "5px"; if (adsContainer) { adsContainer.appendChild(scriptElement); adsContainer.appendChild(insElement); // Rechargez les annonces pour qu'elles soient affichées correctement (adsbygoogle = window.adsbygoogle || []).push({}); } } } }); }, 1000); </script> </body> </html>