JavaScript 메시징을 사용하여 Wix에 드롭다운 기반 PDF URL 전환 통합하기

Temp mail SuperHeros
JavaScript 메시징을 사용하여 Wix에 드롭다운 기반 PDF URL 전환 통합하기
JavaScript 메시징을 사용하여 Wix에 드롭다운 기반 PDF URL 전환 통합하기

Wix 라이브러리 사이트에서 PDF 뷰어 기능 강화하기

방대한 PDF 파일 아카이브를 체계적이고 사용자 친화적인 방식으로 표시하는 것은 공공 도서관 웹사이트에서 사용자 경험을 향상시키는 데 매우 중요합니다. 목표는 방문자가 PDF로 저장된 오래된 신문과 같은 역사적 기록에 원활하게 액세스할 수 있도록 하는 것입니다. 이 프로젝트에서는 Wix, Velo 및 HTML 포함 요소를 사용하여 강력한 시스템의 기반을 만듭니다.

Wix 플랫폼은 iframe을 통해 포함된 요소를 지원하므로 사용자는 PDF 뷰어와 같은 대화형 구성 요소를 추가할 수 있습니다. 이 PDF 뷰어는 iframe을 사용하여 내장되어 있으며 현재 정적 URL은 표시되는 문서를 정의합니다. 그러나 원활한 경험을 위해서는 사용자 입력에 따라 PDF 파일을 동적으로 변경해야 합니다.

문제는 사용자가 두 개의 드롭다운에서 연도와 월을 선택할 수 있도록 허용하는 것입니다. 그러면 표시되는 PDF 문서가 변경됩니다. 여기에는 iframe과 통신하기 위해 JavaScript 메시징을 통합하여 드롭다운 선택에 따라 문서의 URL을 변경할 수 있도록 하는 작업이 포함됩니다.

이 접근 방식은 수많은 정적 Wix 페이지의 필요성을 줄일 뿐만 아니라 라이브러리의 PDF 아카이브에 대한 액세스도 단순화합니다. 아래에서는 Velo 프레임워크와 JavaScript를 사용하여 이를 구현하는 데 필요한 단계와 솔루션을 살펴봅니다.

명령 사용예
PSPDFKit.load() 이 메서드는 특정 컨테이너 내에서 PSPDFKit PDF 뷰어를 초기화합니다. 제공된 URL에서 PDF 파일을 로드하여 포함 요소 내에서 볼 수 있도록 합니다. 이는 PDF 문서를 삽입하고 보기 위해 맞춤화된 PSPDFKit의 JavaScript 라이브러리에만 해당됩니다.
postMessage() 상위 창과 포함된 iframe 간의 통신에 사용됩니다. 이 컨텍스트에서는 기본 페이지에서 iframe으로 메시지를 보내 iframe이 드롭다운 선택 항목에 따라 콘텐츠(PDF URL)를 업데이트할 수 있도록 합니다.
window.addEventListener("message") 이 이벤트 리스너는 postMessage()를 통해 전송된 메시지를 수신하기 위해 iframe 내부에 추가됩니다. 수신된 데이터를 기반으로 iframe에 새 PDF 문서를 동적으로 로드하도록 메시지를 처리합니다.
event.data 메시지 이벤트 핸들러 내에서 event.data에는 상위 창에서 전송된 데이터가 포함되어 있습니다. 이 경우 PSPDFKit 뷰어에 로드하기 위해 선택한 PDF 파일의 URL이 포함됩니다.
document.getElementById() 이 DOM 조작 방법은 ID로 HTML 요소를 검색합니다. 이는 드롭다운 요소에서 사용자 입력을 캡처하는 데 사용되며, 이를 통해 스크립트는 PDF URL 업데이트를 위해 선택한 연도와 월을 결정할 수 있습니다.
DOMContentLoaded DOM이 완전히 로드된 후에만 JavaScript가 실행되도록 하는 이벤트입니다. 이렇게 하면 DOM 요소가 존재하기 전에 액세스하려고 할 때 오류가 발생하는 것을 방지할 수 있습니다.
addEventListener("change") 이 이벤트 리스너는 드롭다운 요소에 변경 사항이 있는지 모니터링합니다. 사용자가 다른 연도나 월을 선택하면 PDF URL을 업데이트하고 해당 문서를 로드하는 기능이 트리거됩니다.
template literals 백틱으로 묶인 템플릿 리터럴을 사용하면 변수를 문자열에 포함할 수 있으므로 선택한 PDF에 대한 URL을 동적으로 쉽게 생성할 수 있습니다. 예: `https://domain.tld/${연도}_${월}_etc.pdf`.
container: "#pspdfkit" PSPDFKit 초기화에서 컨테이너는 PDF 뷰어가 렌더링될 HTML 요소(ID 기준)를 지정합니다. 이는 페이지에서 PDF가 표시될 위치를 정의하는 데 필수적입니다.

Wix에서 드롭다운 선택 기능을 사용한 동적 PDF 로딩

이 솔루션에서는 Wix 페이지의 드롭다운 요소 쌍을 사용하여 포함된 iFrame 내에 표시되는 PDF 파일의 URL을 동적으로 수정합니다. 이 시스템은 보관된 신문 PDF에 쉽게 접근할 수 있는 방법을 모색하는 공공 도서관에 특히 유용합니다. 핵심 기능은 다음에 의해 구동됩니다. 자바스크립트 메시징, 드롭다운에서 사용자 선택 사항을 포함된 PDF 뷰어로 보냅니다. PSPDFKit 뷰어는 iFrame 내부에서 PDF를 렌더링하는 데 사용되며 사용자가 선택한 연도 및 월에 따라 URL을 변경하여 뷰어를 조작합니다. 이는 여러 개의 정적 Wix 페이지를 생성하지 않고도 대규모 아카이브를 표시하는 효율적인 방법을 제공합니다.

첫 번째 드롭다운은 연도를 선택하고, 두 번째 드롭다운은 월을 선택합니다. 사용자가 두 가지를 모두 선택하면 시스템은 해당 PDF 파일에 대한 적절한 URL을 구성합니다. 그만큼 PSPDFKit.load() 메서드는 업데이트된 URL을 기반으로 iFrame에 새 PDF를 로드하므로 이 작업의 핵심입니다. 이 방법은 외부 스크립트를 통해 페이지에 포함되는 PSPDFKit 라이브러리의 일부입니다. 그만큼 포스트메시지() API는 상위 페이지와 iframe 간의 메시징을 허용하는 대체 솔루션에서도 중요합니다. 새 PDF URL이 포함된 메시지를 iframe으로 보내면 PDF 뷰어가 동적으로 업데이트됩니다.

DOM이 완전히 로드된 경우에만 스크립트가 실행되도록 하기 위해 DOM콘텐츠가 로드됨 이벤트. 이렇게 하면 스크립트에서 드롭다운 요소와 PSPDFKit 컨테이너에 액세스할 수 있습니다. 또한 각 드롭다운에 이벤트 리스너를 추가합니다. 사용자가 연도 또는 월을 선택하면 해당 이벤트 리스너가 선택 항목을 캡처하고 올바른 URL로 PDF 뷰어를 다시 로드하는 함수를 호출합니다. 이는 템플릿 리터럴을 사용하여 드롭다운에서 선택한 값으로 URL을 구성하는 간단한 함수를 통해 처리됩니다. 이 방법은 구현하기 쉬울 뿐만 아니라 고도로 모듈화되어 있어 새 아카이브가 추가될 때 쉽게 업데이트할 수 있습니다.

두 번째 접근 방식에서는 다음을 사용합니다. 포스트메시지() 상위 페이지와 iFrame 간에 통신합니다. 상위 페이지는 드롭다운 변경 사항을 수신하고 새 PDF URL이 포함된 메시지를 iFrame으로 보냅니다. iFrame은 이벤트 리스너를 사용하여 메시지를 받습니다. 이 방법은 iframe이 상위 페이지의 DOM과 직접 상호작용할 수 없는 보다 격리된 환경을 처리할 때 유용합니다. 두 가지 방법 모두 내장된 PDF 뷰어의 콘텐츠를 동적으로 업데이트하는 효율적인 방법을 제공하여 여러 정적 페이지의 필요성을 줄이고 사용자 친화적인 탐색 환경을 제공합니다.

Wix에서 PDF 뷰어용 드롭다운 기반 URL 전환 구현하기

JavaScript 및 Velo 프레임워크를 사용하는 프런트엔드 스크립트

// HTML structure for the dropdowns and embed element
<div>
  <label for="yearSelect">Select Year:</label>
  <select id="yearSelect">
    <option value="">--Year--</option>
    <option value="1962">1962</option>
    <option value="1963">1963</option>
    <!-- Add other years dynamically or manually -->
  </select>
  <label for="monthSelect">Select Month:</label>
  <select id="monthSelect">
    <option value="">--Month--</option>
    <option value="January">January</option>
    <option value="February">February</option>
    <!-- Add other months dynamically or manually -->
  </select>
</div>
// Embedded PDF viewer in iframe
<div id="pspdfkit" style="width: 100%; height: 100%; max-width: 1920px;"></div>
<script src="https://cdn.cloud.pspdfkit.com/pspdfkit-web@2024.5.2/pspdfkit.js"></script>
// JavaScript to update URL based on dropdown selection
<script>
document.addEventListener("DOMContentLoaded", () => {
  const yearSelect = document.getElementById("yearSelect");
  const monthSelect = document.getElementById("monthSelect");
  function loadPDF(year, month) {
    if (year && month) {
      const url = `https://domain.tld/${year}_${month}_etc.pdf`;
      PSPDFKit.load({
        container: "#pspdfkit",
        document: url,
      }).catch((error) => {
        console.error("Failed to load PDF:", error);
      });
    }
  }
  yearSelect.addEventListener("change", () => {
    loadPDF(yearSelect.value, monthSelect.value);
  });
  monthSelect.addEventListener("change", () => {
    loadPDF(yearSelect.value, monthSelect.value);
  });
});
</script>

대체 접근 방식: iFrame 통신에 PostMessage API 사용

iframe과 상위 문서 간의 더 나은 격리를 위해 postMessage API를 사용하는 프런트엔드 스크립트

// HTML structure remains the same for dropdowns
// Here, we use iframe with a postMessage-based communication system
<iframe id="pdfViewer" src="about:blank" style="width: 100%; height: 100%;"></iframe>
// JavaScript for sending messages to iframe
<script>
document.addEventListener("DOMContentLoaded", () => {
  const yearSelect = document.getElementById("yearSelect");
  const monthSelect = document.getElementById("monthSelect");
  const iframe = document.getElementById("pdfViewer");
  function updatePDFViewer(year, month) {
    if (year && month) {
      const url = `https://domain.tld/${year}_${month}_etc.pdf`;
      iframe.contentWindow.postMessage({
        type: "updatePDF",
        url: url
      }, "*");
    }
  }
  yearSelect.addEventListener("change", () => {
    updatePDFViewer(yearSelect.value, monthSelect.value);
  });
  monthSelect.addEventListener("change", () => {
    updatePDFViewer(yearSelect.value, monthSelect.value);
  });
});
</script>
// Inside iframe, use this script to receive the message
<script>
window.addEventListener("message", (event) => {
  if (event.data.type === "updatePDF" && event.data.url) {
    PSPDFKit.load({
      container: "#pspdfkit",
      document: event.data.url,
    });
  }
});
</script>

Wix 및 JavaScript 메시징을 통해 PDF 아카이브 접근성 향상

Wix에 포함된 PDF URL을 동적으로 수정하기 위해 드롭다운 요소를 사용할 때 고려해야 할 또 다른 중요한 사항은 아이프레임 메인 페이지가 효율적입니다. JavaScript 메시징을 사용하면 이 두 구성 요소 간에 데이터를 보낼 수 있지만 선택 항목이 업데이트를 트리거하는 방식을 최적화하면 성능과 사용자 경험을 향상시킬 수 있습니다. 이는 입력을 디바운싱하여 수행할 수 있습니다. 즉, 시스템은 각 변경 사항이 아니라 사용자가 선택을 완료한 후에만 PDF 뷰어를 업데이트합니다.

아직 다루지 않은 또 다른 측면은 CORS(교차 원본 리소스 공유). PDF는 외부 서버(예: Digital Ocean)에서 호스팅되므로 서버가 Wix 도메인의 액세스를 허용하도록 구성되어 있는지 확인하는 것이 중요합니다. 서버의 CORS 설정이 올바르게 구성되지 않은 경우 PDF 뷰어가 문서를 로드하지 못해 오류가 발생할 수 있습니다. 두 플랫폼 간의 원활한 통합을 위해서는 PDF 파일을 호스팅하는 서버의 적절한 CORS 헤더가 필수적입니다.

또한 자주 액세스하는 PDF 파일을 미리 로드하여 시스템을 향상시켜 로딩 시간을 줄일 수 있습니다. 미리 로드 전략은 사용자가 여러 달 또는 몇 년 사이를 전환할 가능성이 있을 때 유용합니다. 이러한 파일을 브라우저의 캐시에 저장하면 후속 문서 로드 속도가 빨라져 보다 원활한 사용자 경험을 제공할 수 있습니다. 이는 사용자가 사용 가능한 옵션을 탐색할 때 PDF를 미리 로드하도록 설정할 수 있는 서비스 워커 또는 기타 캐싱 메커니즘을 사용하여 수행할 수 있습니다.

Wix의 동적 PDF 삽입에 대해 자주 묻는 질문

  1. Wix에 드롭다운 선택기를 어떻게 추가하나요?
  2. Wix 편집기를 사용하여 드롭다운 요소를 추가하고, JavaScript를 사용하여 고유 ID를 할당하여 이를 제어할 수 있습니다. 드롭다운 요소는 다음을 통해 PDF URL의 변경 사항을 트리거합니다. document.getElementById().
  3. 무엇을 하는가? PSPDFKit.load() 명령을 해?
  4. 그만큼 PSPDFKit.load() 메소드는 PDF 뷰어를 렌더링하고 특정 PDF 파일을 로드하는 역할을 담당합니다. 이 방법은 PDF 파일을 동적으로 표시하는 데 사용되는 PSPDFKit 라이브러리의 일부입니다.
  5. 사용할 수 있나요? postMessage() 교차 출처 통신을 위해?
  6. 예, postMessage() API는 상위 페이지와 iFrame 간 등 서로 다른 출처 간 통신을 위해 특별히 설계되었으며 이는 이 구현에 매우 중요합니다.
  7. PDF를 로드할 때 오류를 어떻게 처리합니까?
  8. 다음을 추가하여 오류를 처리할 수 있습니다. .catch() ~을 차단하다 PSPDFKit.load() 로딩 과정에서 발생하는 오류를 포착하고 적절한 오류 메시지를 표시하는 기능입니다.
  9. CORS용 서버를 구성해야 합니까?
  10. 예, 귀하의 PDF가 다른 도메인에서 호스팅되는 경우 서버가 적절한 도메인으로 설정되어 있는지 확인해야 합니다. CORS Wix 사이트가 문서에 접근할 수 있도록 허용하는 헤더입니다.

동적 PDF 디스플레이에 대한 최종 생각

이 솔루션은 단일 페이지에 대규모 PDF 파일 아카이브를 표시하는 프로세스를 단순화합니다. 연도와 월을 선택하는 두 개의 드롭다운 요소를 사용하면 Wix 페이지를 여러 개 만들지 않고도 PDF 뷰어를 동적으로 업데이트할 수 있습니다.

Velo 프레임워크의 유연성과 드롭다운 및 iFrame 간의 JavaScript 메시징을 결합한 이 방법은 기록 데이터를 구성하고 표시하는 효율적인 방법을 제공합니다. 도서관 아카이브와 같은 공개 웹사이트에 맞게 확장 가능하고 사용자 친화적입니다.

Wix 및 JavaScript를 사용한 동적 PDF 로딩에 대한 소스 및 참조
  1. Velo 프레임워크를 사용하여 Wix에서 HTML iFrame 요소 및 JavaScript 메시징 작업에 대한 자세한 문서를 제공합니다. 방문하다 Wix 개발자 문서 자세한 내용은
  2. JavaScript 라이브러리를 사용하여 iFrame 내에 PDF를 포함하고 로드하는 방법을 자세히 설명하는 PSPDFKit의 공식 문서입니다. 여기에서 액세스하세요: PSPDFKit 문서 .
  3. Digital Ocean과 같은 외부 서버에서 적절한 PDF 로딩을 보장하기 위해 CORS(교차 원본 리소스 공유) 구현에 대한 가이드입니다. 자세한 내용은 다음에서 확인할 수 있습니다. CORS의 MDN 웹 문서 .