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 구성 요소와 달리 내장 현지화 지원이 부족합니다. 현지화가 중요 하므로이 제한 사항을 해결할 것입니다. 이 기사는 두 가지 주요 목표를 달성하는 것을 목표로합니다.
- WordPress 편집기 블록 내에서 문서화를위한 Markdown 사용.
- 사용자의 언어를 기반으로 문서 번역 구현.
마크 다운 컨텐츠로드
/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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

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

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

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

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

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

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

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


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

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

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

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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