Picked colors

Clear All

자바스크립트

const colorPickerBtn = document.querySelector(\\\"#color-picker\\\");const clearAll = document.querySelector(\\\".clear-all\\\");const colorList = document.querySelector(\\\".all-colors\\\");const pickedColors = JSON.parse(localStorage.getItem(\\\"picked-colors\\\") || \\\"[]\\\");const copyColor = (elem) => {    elem.innerText = \\\"Copied\\\";    navigator.clipboard.writeText(elem.dataset.color);    setTimeout(() => elem.innerText = elem.dataset.color, 1000);}const showColor = () => {    if (!pickedColors.length) return;    colorList.innerHTML = pickedColors.map(color => `        
  • ${color}
  • `).join(\\\"\\\"); document.querySelector(\\\".picked-colors\\\").classList.remove(\\\"hide\\\"); document.querySelectorAll(\\\".color\\\").forEach(li => { li.addEventListener(\\\"click\\\", e => copyColor(e.currentTarget.lastElementChild)); });}showColor();const activateEyeDropper = () => { document.body.style.display = \\\"none\\\"; setTimeout(async () => { try { const eyeDropper = new EyeDropper(); const { sRGBHex } = await eyeDropper.open(); navigator.clipboard.writeText(sRGBHex); if (!pickedColors.includes(sRGBHex)) { pickedColors.push(sRGBHex); localStorage.setItem(\\\"picked-colors\\\", JSON.stringify(pickedColors)); showColor(); } } catch (error) { alert(\\\"Failed to copy the color code!\\\"); } document.body.style.display = \\\"block\\\"; }, 10);}const clearAllColors = () => { pickedColors.length = 0; localStorage.setItem(\\\"picked-colors\\\", JSON.stringify(pickedColors)); document.querySelector(\\\".picked-colors\\\").classList.add(\\\"hide\\\");}clearAll.addEventListener(\\\"click\\\", clearAllColors);colorPickerBtn.addEventListener(\\\"click\\\", activateEyeDropper);

    CSS

    @import url(\\'https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600&display=swap\\');* {  margin: 0;  padding: 0;  box-sizing: border-box;  font-family: \\\"Poppins\\\", sans-serif;}.popup {  width: 350px;  background: #fff;}.popup :where(.picker, header, .all-colors) {  display: flex;  align-items: center;}.popup .picker {  padding: 30px 0;  background: #E3F2FD;  justify-content: center;}.picker #color-picker {  border: none;  outline: none;  color: #fff;  font-size: 1rem;  cursor: pointer;  padding: 10px 20px;  border-radius: 5px;  background: #5372F0;  transition: 0.3s ease;}#color-picker:hover {  background: #2c52ed;}.picked-colors {  margin: 10px 15px;}.picked-colors header {  justify-content: space-between;}header .title {  font-size: 1rem;}header .clear-all {  cursor: pointer;  font-size: 0.9rem;  color: #5372F0;}header .clear-all:hover {  color: #143feb;}.picked-colors.hide {  display: none;}.picked-colors .all-colors {  flex-wrap: wrap;  list-style: none;  margin: 10px 0 15px;}.all-colors .color {  display: flex;  cursor: pointer;  margin-bottom: 10px;  width: calc(100% / 3);}.all-colors .rect {  height: 21px;  width: 21px;  display: block;  margin-right: 8px;  border-radius: 5px;}.all-colors .color span {  font-size: 0.96rem;  font-weight: 500;  text-transform: uppercase;  font-family: \\\"Open sans\\\";}

    라이브 데모

    위의 설치 지침에 따라 확장 프로그램을 로컬에서 테스트할 수 있습니다. 설치되면 확장 프로그램의 팝업을 통해 색상을 선택하고 색상 기록을 관리할 수 있습니다.

    결론

    이 색상 선택기 확장은 EyeDropper API를 브라우저 확장에 통합하여 사용자에게 색상 선택 및 관리를 위한 편리한 도구를 제공하는 방법을 보여줍니다. 디자이너이든 색상 작업을 즐기는 사람이든 이 확장 프로그램을 사용하면 작업 흐름이 향상될 수 있습니다.

    크레딧

    작가

    Abhishek Gurjar는 실용적이고 기능적인 웹 애플리케이션 제작에 열정을 갖고 있는 헌신적인 웹 개발자입니다. GitHub에서 그의 프로젝트를 더 확인해 보세요.

    ","image":"http://www.luping.net/uploads/20240916/172648405066e80e527c1e7.jpg","datePublished":"2024-11-01T06:40:36+08:00","dateModified":"2024-11-01T06:40:36+08:00","author":{"@type":"Person","name":"luping.net","url":"https://www.luping.net/articlelist/0_1.html"}}
    "일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
    첫 장 > 프로그램 작성 > 색상 선택기 확장 구축

    색상 선택기 확장 구축

    2024-11-01에 게시됨
    검색:184

    Building a Color Picker Extension

    소개

    이 블로그 게시물에서는 간단하면서도 강력한 색상 선택 브라우저 확장 프로그램을 만드는 방법을 살펴보겠습니다. 이 확장 프로그램을 사용하면 사용자는 간단한 상호 작용을 통해 화면에서 쉽게 색상을 선택하고, 선택한 색상 기록을 확인하고, 색상 팔레트를 관리할 수 있습니다.

    프로젝트 개요

    색상 선택기 확장은 다음 작업에 대한 사용자 친화적인 인터페이스를 제공합니다.

    • EyeDropper API를 사용하여 화면에서 색상을 선택하세요.
    • 선택한 색상의 기록을 봅니다.
    • 색상 코드를 클립보드에 복사합니다.
    • 선택한 색상을 모두 지웁니다.

    특징

    • 색상 선택: EyeDropper API를 사용하여 화면 어느 부분에서나 색상을 선택합니다.
    • 색상 기록: 선택한 색상 목록을 쉽게 액세스하여 관리합니다.
    • 클립보드 복사: 색상 코드를 클립보드에 빠르게 복사합니다.
    • 모두 지우기: 한 번의 클릭으로 기록에서 모든 색상을 제거합니다.

    사용된 기술

    • HTML: 확장 프로그램 팝업에 대한 마크업입니다.
    • CSS: 팝업 및 해당 요소에 대한 스타일 지정.
    • JavaScript: 색상 선택, 색상 기록 표시, 클립보드 작업 관리를 처리합니다.
    • EyeDropper API: 화면에서 색상을 선택할 수 있습니다.
    • localStorage: 세션 전체에서 선택한 색상을 저장합니다.

    프로젝트 구조

    1. HTML (index.html): 색상 선택기 인터페이스의 구조를 포함합니다.
    2. CSS(style.css): 팝업과 해당 요소의 스타일을 지정합니다.
    3. JavaScript(script.js): 색상 선택, 표시, 로컬 저장소와의 상호 작용 등의 기능을 관리합니다.
    4. 매니페스트(manifest.json): 확장의 메타데이터 및 구성을 정의합니다.

    설치

    로컬에서 확장 프로그램을 테스트하려면:

    1. 파일을 디렉터리에 저장합니다.
    2. Chrome을 열고 chrome://extensions/로 이동합니다.
    3. "개발자 모드"를 활성화합니다(오른쪽 상단에서 토글).
    4. "압축해제된 항목 로드"를 클릭하고 프로젝트 디렉터리를 선택하세요.

    용법

    1. 색상 선택기를 활성화하려면 확장 팝업에서 '색상 선택' 버튼을 클릭하세요.
    2. 화면 어디에서나 색상을 선택하세요.
    3. 팝업에서 선택한 색상을 보고 색상을 클릭하여 해당 코드를 클립보드에 복사하세요.
    4. 기록에서 모든 색상을 제거하려면 "모두 지우기"를 클릭하세요.

    코드 설명

    HTML

    
    
        
        
    
    
        
    
    
    

    자바스크립트

    const colorPickerBtn = document.querySelector("#color-picker");
    const clearAll = document.querySelector(".clear-all");
    const colorList = document.querySelector(".all-colors");
    const pickedColors = JSON.parse(localStorage.getItem("picked-colors") || "[]");
    
    const copyColor = (elem) => {
        elem.innerText = "Copied";
        navigator.clipboard.writeText(elem.dataset.color);
        setTimeout(() => elem.innerText = elem.dataset.color, 1000);
    }
    
    const showColor = () => {
        if (!pickedColors.length) return;
        colorList.innerHTML = pickedColors.map(color => `
            
  • ${color}
  • `).join(""); document.querySelector(".picked-colors").classList.remove("hide"); document.querySelectorAll(".color").forEach(li => { li.addEventListener("click", e => copyColor(e.currentTarget.lastElementChild)); }); } showColor(); const activateEyeDropper = () => { document.body.style.display = "none"; setTimeout(async () => { try { const eyeDropper = new EyeDropper(); const { sRGBHex } = await eyeDropper.open(); navigator.clipboard.writeText(sRGBHex); if (!pickedColors.includes(sRGBHex)) { pickedColors.push(sRGBHex); localStorage.setItem("picked-colors", JSON.stringify(pickedColors)); showColor(); } } catch (error) { alert("Failed to copy the color code!"); } document.body.style.display = "block"; }, 10); } const clearAllColors = () => { pickedColors.length = 0; localStorage.setItem("picked-colors", JSON.stringify(pickedColors)); document.querySelector(".picked-colors").classList.add("hide"); } clearAll.addEventListener("click", clearAllColors); colorPickerBtn.addEventListener("click", activateEyeDropper);

    CSS

    @import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600&display=swap');
    * {
      margin: 0;
      padding: 0;
      box-sizing: border-box;
      font-family: "Poppins", sans-serif;
    }
    .popup {
      width: 350px;
      background: #fff;
    }
    .popup :where(.picker, header, .all-colors) {
      display: flex;
      align-items: center;
    }
    .popup .picker {
      padding: 30px 0;
      background: #E3F2FD;
      justify-content: center;
    }
    .picker #color-picker {
      border: none;
      outline: none;
      color: #fff;
      font-size: 1rem;
      cursor: pointer;
      padding: 10px 20px;
      border-radius: 5px;
      background: #5372F0;
      transition: 0.3s ease;
    }
    #color-picker:hover {
      background: #2c52ed;
    }
    .picked-colors {
      margin: 10px 15px;
    }
    .picked-colors header {
      justify-content: space-between;
    }
    header .title {
      font-size: 1rem;
    }
    header .clear-all {
      cursor: pointer;
      font-size: 0.9rem;
      color: #5372F0;
    }
    header .clear-all:hover {
      color: #143feb;
    }
    .picked-colors.hide {
      display: none;
    }
    .picked-colors .all-colors {
      flex-wrap: wrap;
      list-style: none;
      margin: 10px 0 15px;
    }
    .all-colors .color {
      display: flex;
      cursor: pointer;
      margin-bottom: 10px;
      width: calc(100% / 3);
    }
    .all-colors .rect {
      height: 21px;
      width: 21px;
      display: block;
      margin-right: 8px;
      border-radius: 5px;
    }
    .all-colors .color span {
      font-size: 0.96rem;
      font-weight: 500;
      text-transform: uppercase;
      font-family: "Open sans";
    }
    

    라이브 데모

    위의 설치 지침에 따라 확장 프로그램을 로컬에서 테스트할 수 있습니다. 설치되면 확장 프로그램의 팝업을 통해 색상을 선택하고 색상 기록을 관리할 수 있습니다.

    결론

    이 색상 선택기 확장은 EyeDropper API를 브라우저 확장에 통합하여 사용자에게 색상 선택 및 관리를 위한 편리한 도구를 제공하는 방법을 보여줍니다. 디자이너이든 색상 작업을 즐기는 사람이든 이 확장 프로그램을 사용하면 작업 흐름이 향상될 수 있습니다.

    크레딧

    • EyeDropper API: 화면에서 색상을 선택하는 기능을 제공합니다.
    • 팝핀스 글꼴: 팝업의 텍스트 스타일을 지정하는 데 사용됩니다.

    작가

    Abhishek Gurjar는 실용적이고 기능적인 웹 애플리케이션 제작에 열정을 갖고 있는 헌신적인 웹 개발자입니다. GitHub에서 그의 프로젝트를 더 확인해 보세요.

    릴리스 선언문 이 기사는 https://dev.to/abhishekgurjar/building-a-color-picker-extension-20i9 ?1에서 재현됩니다.
    최신 튜토리얼 더>

    부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

    Copyright© 2022 湘ICP备2022001581号-3