Rumah >hujung hadapan web >tutorial js >Bagaimanakah Saya Boleh Menukar Nilai Warna RGB kepada Hex dalam JavaScript?

Bagaimanakah Saya Boleh Menukar Nilai Warna RGB kepada Hex dalam JavaScript?

Patricia Arquette
Patricia Arquetteasal
2024-12-19 10:22:13959semak imbas

How Can I Convert RGB Color Values to Hex in JavaScript?

Mendapatkan Nilai Warna Hex daripada RGB

JQuery yang disediakan membolehkan anda mendapatkan semula nilai RGB warna latar belakang elemen. Walau bagaimanapun, bagaimana jika anda memerlukan nilai heks sebaliknya?

Penyelesaian

Untuk menukar nilai RGB kepada nilai hex, pertimbangkan fungsi satu baris berikut:

const rgba2hex = (rgba) => `#${rgba.match(/^rgba?\((\d+),\s*(\d+),\s*(\d+)(?:,\s*(\d+\.{0,1}\d*))?\)$/).slice(1).map((n, i) => (i === 3 ? Math.round(parseFloat(n) * 255) : parseFloat(n)).toString(16).padStart(2, '0').replace('NaN', '')).join('')}`

Jawapan Diperbaiki (2021)

Dengan kemajuan dalam ciri EcmaScript, versi rgb2hex yang lebih ringkas dan dikemas kini ialah:

const rgb2hex = (rgb) => `#${rgb.match(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/).slice(1).map(n => parseInt(n, 10).toString(16).padStart(2, '0')).join('')}`

Contoh Penggunaan

Anda boleh menggunakan fungsi ini seperti berikut:

console.log(rgb2hex('rgb(0,0,0)')) // '#000000'
console.log(rgb2hex('rgb(255, 255, 255)')) // '#ffffff'
console.log(rgb2hex('rgb(255,0,0)')) // '#ff0000'
console.log(rgb2hex('rgb(38, 170, 90)')) // '#26aa5a'

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menukar Nilai Warna RGB kepada Hex dalam JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn