JS에서 반응형 아이콘 버튼 만들기
2702 단어 cssjavascriptstylingbeginners
나뭇잎 버튼과 문 버튼을 클릭하면 각각 새 식물 또는 새 방을 만들기 위한 양식을 렌더링합니다. 내 목표는 다음과 같이 마우스가 아이콘 위에 있을 때와 해당 양식이 열릴 때 아이콘이 초기 녹색에서 대비되는 주황색으로 변경되도록 하는 것입니다.
이를 달성하는 것은 실제로 매우 간단합니다. 일치하는 형식을 렌더링하는 기능 버튼이 이미 있으므로 특정 DOM 이벤트, 특히 마우스 클릭 및 마우스 호버 시 표시되는 이미지를 변경하는 방법을 찾기만 하면 되었습니다.
첫 번째 단계는 내 버튼 아이콘의 녹색 및 주황색 버전을 애플리케이션의 로컬 파일 구조에 추가하는 것이었습니다. 외부 소스도 이를 위해 작동할 수 있습니다.
내 .html 파일에서 잎의
<div>
태그에 클래스green-leaf
가 있는 <button>
를 추가하고 문<div>
태그에 클래스green-door
가 있는 <button>
를 추가했습니다.<button id="leaf-button"><div class="green-leaf"></div></button>
green-
클래스는 버튼 내의 div에 대한 일종의 기본 상태 역할을 합니다.내 .css 파일에 다음 줄을 추가합니다.
.green-leaf {
content: url("../images/green-leaf.png");
}
.orange-leaf {
content: url("../images/orange-leaf.png");
}
.green-leaf:hover {
content: url("../images/orange-leaf.png");
}
.green-door {
content: url("../images/green-door.png");
}
.orange-door {
content: url("../images/orange-door.png");
}
.green-door:hover {
content: url("../images/orange-door.png");
}
이제 요소에
green-leaf
클래스가 있는 경우 콘텐츠는 녹색 잎의 로컬 이미지 파일로 연결되는 해당 URL에서 제공됩니다. 클래스가 orange-leaf
로 변경되면 내용이 오렌지 잎의 로컬 이미지 파일로 향하는 URL로 변경됩니다. 이 콘텐츠 변경은 미열린 양식의 버튼(녹색 아이콘으로 표시됨)을 마우스로 가리킬 때도 발생합니다.이제 남은 것은 해당 요소에 JS 이벤트 리스너를 추가하는 것입니다. 이것은 또한 매우 간단합니다. 매우 기본적인 예는 다음과 같습니다.
//grab the div containing the image
let leaf = document.querySelector("#leaf-button div")
//add an event listener to the leaf with an anonymous function
leaf.addEventListener("click", function(){
leaf.classList.toggle("green-leaf")
leaf.classList.toggle("orange-leaf")
}
이제 버튼을 클릭할 때마다 green-leaf 또는 orange-leaf 클래스를 번갈아 가며 프로세스에서 다른 CSS 규칙을 적용합니다.
Reference
이 문제에 관하여(JS에서 반응형 아이콘 버튼 만들기), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/spenserbrinkman/making-a-responsive-icon-button-in-js-41c6텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)