찾다
웹 프론트엔드CSS 튜토리얼WordPress 블록 편집기에서 Markdown 및 현지화 사용

WordPress 블록 편집기에서 Markdown 및 현지화 사용

WordPress 편집기 내에 직접 문서를 표시해야합니까? 이 기사는 간소화 된 문서 관리 및 현지화를 위해 Markdown을 활용하여 최적의 접근 방식을 살펴 봅니다.

React 구성 요소와 HTML은 직관적 인 것처럼 보일 수 있지만 광범위한 문서를 위해 다루기 어려워지고 유지하기가 어려워 질 수 있습니다. 이 예제는 모달에 문서를 보여주는 이전 기사에서 다음과 같습니다.

 const cachecontroldescription = () => {
  반품 (
    <p>캐시 제어 헤더에는 요청과 관련된 모든 필드/지시문의 최소 최대 연령 값이 포함되거나 <code>no-store if the max-age is 0</code>
  ))
}</p>

Markdown은 더 깨끗한 솔루션을 제공합니다. 위는 Markdown 파일 ( /docs/cache-control.md )으로 리팩토링 될 수 있습니다.

 캐시 제어 헤더에는 요청과 관련된 모든 필드/지시문의 최소 최대 연령 값이 포함되거나 최대 연령이 0 인 경우 'No-Store'가 포함됩니다.

Markdown vs. HTML : 장점과 단점

Markdown은 프로세스를 단순화하지만 POT 파일을 사용하여 쉽게 번역 할 수있는 React 구성 요소와 달리 내장 현지화 지원이 부족합니다. 현지화가 중요 하므로이 제한 사항을 해결할 것입니다. 이 기사는 두 가지 주요 목표를 달성하는 것을 목표로합니다.

  1. WordPress 편집기 블록 내에서 문서화를위한 Markdown 사용.
  2. 사용자의 언어를 기반으로 문서 번역 구현.

마크 다운 컨텐츠로드

/docs/cache-control.md 만들어 HTML-Converted 컨텐츠를 가져오고 렌더링 할 수 있습니다.

 '../docs/cache-control.md'에서 Cachecontroldocumentation 가져 오기;

const cachecontroldescription = () => {
  반품 (
    <div dangerouslysetinnerhtml="{{" __html: cachecontroldocumentation></div>
  );
}

이것은 WordPress 편집기의 핵심 모듈 Bundler (버전 4.42) 인 Webpack에 의존합니다. Markdown 및 HTML 로더를 처리하기 위해 WebPack의 구성을 사용자 정의 할 것입니다.

블록의 루트에서 webpack.config.js 작성하십시오.

 const defaultConfig = require ( '@wordpress/scripts/config/webpack.config');

module.exports = {
  ... DefaultConfig,
  모듈 : {
    ... defaultConfig.Module,
    규칙 : [
      ... defaultConfig.Module.rules,
      {
        테스트 : /\.md$/,
        사용: [
          {로더 : "html-loader"},
          {로더 : "Markdown-Loader"}
        ]]
      }
    ],,
  },
};

필요한 패키지 설치 :

 NPM 설치--Save Dev Markdown-Loader HTML-Loader

개선 된 조직의 경우 Webpack Alias ​​( @docs /docs 가리키는)를 추가하십시오.

 const path = 요구 ( '경로');
config.resolve.alias [ '@docs'] = path.resolve (process.cwd (), 'docs/');

이제 가져 오기 단순화 :

 '@docs/cache-control.md'에서 Cachecontroldocumentation 가져 오기;

현지화 문서화

직접 마크 다운 번역이 가능하지 않으므로 언어 ​​별 마크 다운 파일을 만듭니다.

  • /docs/en/cache-control.md
  • /docs/fr/cache-control.md
  • /docs/zh/cache-control.md

이 접근법은 또한 지역별 변형 (예 : /docs/en_US/cache-control.md )을 처리 할 수 ​​있습니다.

사용자 언어 검색

사용자의 언어는 get_locale() 사용하여 얻어지고 언어 코드를 추출하기 위해 구문 분석합니다.

 함수 get_locale_language () : String {
  $ localeparts = Explode ( '_', get_locale ());
  Return $ LocalEparts [0];
}

이 언어 코드는 wp_localize_script() 를 통해 블록으로 전달됩니다.

 wp_locaite_script (
  $ blockscriptRegistrationName,
  'GraphQlapicacheControl',
  [의 뜻
    'userLang'=> get_locale_language (),
  ]]
);

이제 block에서 window.graphqlApiCacheControl.userLang 으로 액세스 할 수 있습니다.

동적 수입

사용자의 언어는 런타임에만 알려져 있으므로 동적 가져 오기를 사용합니다.

 const lang = window.graphqlapicachecontrol.userlang;
import (`@docs/$ {lang}/cache-control.md`). (module => {
  // ...
});

내용은 obj.default 를 통해 액세스합니다.

 CONT CACHECONTROLCONTENT = import (`@docs/$ {lang}/cache-control.md`) .then (obj => obj.default);

이것은 getMarkdownContent 함수로 캡슐화됩니다.

 const getMarkdownContent = (filename, lang) => {
  return import (/ * WebPackChunkName : "docs/[request]" */`@docs/$ {lang}/$ {filename} .md`)
    . (obj => obj.default);
};

/* webpackChunkName: "docs/[request]" */ 댓글은 체계적인 청크 관리를 보장합니다.

공개 길을 설정합니다

publicPath 는 Webpack이 동적으로로드 된 청크를 찾는 데 중요합니다. 이는 하드 코딩, 환경 변수를 통해 설정하거나 런타임에 전달 될 수 있습니다. 이 예에서는 다음과 같이 전달하겠습니다.

 $ blockpublicpath = plugin_dir_url (__ file__). '/블록/캐시 제어/빌드/';
wp_locaite_script (
  $ blockscriptRegistrationName,
  'GraphQlapicacheControl',
  [의 뜻
    // ...
    'publicpath'=> $ blockpublicpath,
  ]]
);

그런 다음 JavaScript 측에 설정하십시오.

 __webpack_public_path__ = wind

기본 언어 폴백

폴백 메커니즘은 누락 된 번역을 처리합니다.

 const getMarkdownContEntorUsedEfault = (filename, defaultlang, lang) => {
  return getMarkdownContent (Filename, Lang)
    .catch (err => getMarkdownContent (filename, defaultLang));
};

모달과 통합

마지막으로 마크 다운 컨텐츠는 모달에 통합됩니다.

 '@wordpress/element'에서 {usestate, useeffect} import;
// ... 기타 수입

CONT CACHECONTROLCONTENTMODAL = (props) => {
  // ...
  const [page, setpage] = usestate ([]);

  useeffect (() => {
    getMarkdownContentOrusedEfault (filename, defaultlang, lang). then (value => {
      setPage (값);
    });
  }, []);

  반품 (
    <contentmodal content="{page}"></contentmodal>
  );
};

이 접근법은 WordPress 편집기 내에서 강력하고 유지 관리 가능하며 현지화 된 문서화 시스템을 제공합니다.

위 내용은 WordPress 블록 편집기에서 Markdown 및 현지화 사용의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
@keyframes CSS : 가장 많이 사용되는 트릭@keyframes CSS : 가장 많이 사용되는 트릭May 08, 2025 am 12:13 AM

@keyframesispopularduetoitstativerstatility 및 powerincreatingsmoothcssanimations.keytricksinclude : 1) states 사이에 moothtransitionsbettites, 2) 애니메이션 multiplepropertiessimultory, 3) vendorPixesforBrowsercompatibility, 4) 빗질을 사용하여

CSS 카운터 : 자동 번호 매기기에 대한 포괄적 인 안내서CSS 카운터 : 자동 번호 매기기에 대한 포괄적 인 안내서May 07, 2025 pm 03:45 PM

csScounterSearedTomanageAutomaticNumberingInberingInwebDesigns.1) 1) theCanbeusedfortablestoffContents, ListItems 및 CustomNumbering.2) AdvancedUsesInSinestedNumberingsystems.3) CreativeUseNvolvecust를 CreativeSinvolecust.4) CreativeSinvolvecust

스크롤 구동 애니메이션을 사용한 현대 스크롤 그림자스크롤 구동 애니메이션을 사용한 현대 스크롤 그림자May 07, 2025 am 10:34 AM

특히 모바일 장치에 스크롤 그림자를 사용하는 것은 Chris가 이전에 다룬 미묘한 UX입니다. Geoff는 애니메이션 타임 라인 속성을 사용하는 새로운 접근 방식을 다루었습니다. 또 다른 방법이 있습니다.

이미지 맵 재 방문이미지 맵 재 방문May 07, 2025 am 09:40 AM

빠른 새로 고침을 통해 실행합시다. 이미지 맵은 html 3.2로 돌아가는데, 먼저 서버 측 맵과 클라이언트 측지 맵은 맵 및 영역 요소를 사용하여 이미지를 통해 클릭 가능한 영역을 정의했습니다.

DEVS 상태 : 모든 개발자를위한 설문 조사DEVS 상태 : 모든 개발자를위한 설문 조사May 07, 2025 am 09:30 AM

Devs State Survey는 이제 참여에 개방되어 있으며, 이전 설문 조사와 달리 코드, 직장, 건강, 취미 등을 제외한 모든 것을 포함합니다. 

CSS 그리드는 무엇입니까?CSS 그리드는 무엇입니까?Apr 30, 2025 pm 03:21 PM

CSS 그리드는 복잡하고 반응이 좋은 웹 레이아웃을 만드는 강력한 도구입니다. 디자인을 단순화하고 접근성을 향상 시키며 이전 방법보다 더 많은 제어를 제공합니다.

CSS Flexbox 란 무엇입니까?CSS Flexbox 란 무엇입니까?Apr 30, 2025 pm 03:20 PM

기사는 반응 형 설계에서 공간의 효율적인 정렬 및 분포를위한 레이아웃 방법 인 CSS Flexbox에 대해 설명합니다. Flexbox 사용을 설명하고 CSS 그리드와 비교하고 브라우저 지원 세부 사항을 설명합니다.

CSS를 사용하여 웹 사이트를 반응하게 만드는 방법은 무엇입니까?CSS를 사용하여 웹 사이트를 반응하게 만드는 방법은 무엇입니까?Apr 30, 2025 pm 03:19 PM

이 기사는 Viewport Meta 태그, 유연한 그리드, 유체 미디어, 미디어 쿼리 및 상대 장치를 포함하여 CSS를 사용하여 반응 형 웹 사이트를 만드는 기술에 대해 설명합니다. 또한 CSS 그리드 및 Flexbox를 함께 사용하여 CSS 프레임 워크를 권장합니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.