기본 HTML: 대화 상자
dialog
상자를 만들려면 div를 만들고 숨긴 다음 사용자가 특정 작업을 수행할 때 표시해야 했습니다. 이것은 함께 던지기가 쉬웠지만 접근성이 좋지 않았습니다. 일반적인 오류는 탭 인덱스에 dialog
의 요소를 남겨 두어 사용자가 이동하기 전에 dialog
의 모든 요소를 탭해야 한다는 것을 의미했습니다.아마 해결하셨겠지만 기본
dialog
요소와 이를 사용하는 방법에 대해 작성하겠습니다. 글을 쓰는 시점에서 지원은 당연히 그다지 좋지 않습니다.data:image/s3,"s3://crabby-images/9ab15/9ab15f6ee71bc11226f2f8160f58adda4e82255e" alt=""
대화 상자 요소
나는 항상 Mozilla의 개발 사이트를 방문하여 새로운 요소에 대해 배우는 것을 좋아하므로 여기에서 설명합니다.
The HTML
<dialog>
element represents a dialog box or other interactive component, such as an inspector or window.
좋아, 하지만 그게 무슨 뜻이야? 구문은 충분히 간단해 보이므로 시도해 봅시다.
<dialog open> Test dialog </dialog>
지원되는 브라우저에서 어떻게 보이는지.
data:image/s3,"s3://crabby-images/130d8/130d8ac35d12ea31f2c007ad96a3655db04f2e9b" alt=""
읽어주셔서 감사합니다... 오, 아직 끝나지 않았습니다. 우리는
dialog
와 상호 작용해야 합니다. 항상 거기에 있는 것은 그다지 도움이 되지 않습니다. Mozilla는 사용 예제를 제공하지만 이에 대한 정보는 제공하지 않으므로 다른 곳을 살펴보겠습니다.w3 사양
확실하지 않은 경우 spec으로 이동하면
dialog
와 상호 작용할 수 있는 3가지 기능이 있으며 각각 설명이 있습니다.dialog . show( [
anchor
] )
Displays the dialog element.
The argument, if provided, provides an anchor point to which the element will be fixed.dialog . showModal( [
anchor
] )
Displays the dialog element and makes it the top-most modal dialog.
The argument, if provided, provides an anchor point to which the element will be fixed.
This method honors the autofocus attribute.dialog . close( [
result
] )
Closes the dialog element.
The argument, if provided, provides a return value.
이것을 실천에 옮기는
자, 이것은 이것을 실행에 옮기는 나만의 방법입니다. 이런 식으로 하면 안 된다고 생각하시면 알려주세요.
label
를 사용하면 레이블을 연결할 요소를 ID로 가리킬 수 있는 for
속성이 있습니다. 이것은 실제 속성이 아니기 때문에 data-modal-for
데이터를 갖도록 영감을 주었습니다.<button data-modal-for="testDialog" open>Open modal</button>
<dialog id="testDialog">
<h1>An example of a native Dialog element</h1>
<p>This is a dialog box and, believe it or not, it's built into HTML, sure we needed some javascript to open it but hey, it's a start.</p>
<button data-modal-for="testDialog" close>Close modal</button>
</dialog>
dialog {
border: none;
border-radius: 2px;
box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16), 0 3px 6px rgba(0, 0, 0, 0.23);
max-width: 60vw;
}
const modalTriggers = document.querySelectorAll(`[data-modal-for]`);
for (let trigger of modalTriggers) {
const modal = document.getElementById(trigger.dataset.modalFor);
trigger.addEventListener('click', () => {
trigger.hasAttribute('open') && modal.showModal();
trigger.hasAttribute('close') && modal.close();
});
}
다음은 지원되는 브라우저에서 버튼을 누른 후의 모습입니다.
data:image/s3,"s3://crabby-images/61314/613148f7aabb23f7fb8a3b81e455506647e8bb82" alt=""
자바스크립트를 설명하라
나는 당신이 자바스크립트가 무엇을 하는지 알고 있다고 가정할 것이므로 내가 왜 이렇게 했는지 설명할 것입니다.
먼저
data-modal-for
속성을 지정한 모든 요소를 선택한 다음 여기에 eventListeners를 추가합니다. 또한 trigger
요소에 open
또는 close
속성을 부여하여 dialog
를 변경하는 방법을 지정합니다.이것이 동적으로 생성된 요소가 즉시 작동하지 않는다는 것을 의미한다는 것을 알고 있지만 이것이 여전히 내가 생각할 수 있는 최선의 방법이었습니다.
종료
이
things we can't really use yet but maybe one day
게시물이 마음에 드시면 알려주세요. 플랫폼의 발전이 흥미롭고 공유하는 것을 즐깁니다.읽어주셔서 감사합니다 🦄🦄😀😀❤🦄
Reference
이 문제에 관하여(기본 HTML: 대화 상자), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/link2twenty/native-html-dialog-boxes-192b텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)