分享

js 实现颜色值格式转换 rgb和十六进制的转换

 黄三岁大爱人生 2020-02-08

本文章是以prototype原型的方式,给string字符串类型添加方法,用于实现颜色值格式的转换。

如果你不用原型方法,那么你只要借鉴实现方法就好了。

 

RGB转换为16进制

  1. String.prototype.colorHex = function () {
  2. // RGB颜色值的正则
  3. var reg = /^(rgb|RGB)/;
  4. var color = this;
  5. if (reg.test(color)) {
  6. var strHex = "#";
  7. // 把RGB的3个数值变成数组
  8. var colorArr = color.replace(/(?:\(|\)|rgb|RGB)*/g, "").split(",");
  9. // 转成16进制
  10. for (var i = 0; i < colorArr.length; i++) {
  11. var hex = Number(colorArr[i]).toString(16);
  12. if (hex === "0") {
  13. hex += hex;
  14. }
  15. strHex += hex;
  16. }
  17. return strHex;
  18. } else {
  19. return String(color);
  20. }
  21. };

使用方法:

"rgb(255,255,255)".colorHex();  // #ffffff

 

16进制转换为RGB

  1. String.prototype.colorRgb = function () {
  2. // 16进制颜色值的正则
  3. var reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/;
  4. // 把颜色值变成小写
  5. var color = this.toLowerCase();
  6. if (reg.test(color)) {
  7. // 如果只有三位的值,需变成六位,如:#fff => #ffffff
  8. if (color.length === 4) {
  9. var colorNew = "#";
  10. for (var i = 1; i < 4; i += 1) {
  11. colorNew += color.slice(i, i + 1).concat(color.slice(i, i + 1));
  12. }
  13. color = colorNew;
  14. }
  15. // 处理六位的颜色值,转为RGB
  16. var colorChange = [];
  17. for (var i = 1; i < 7; i += 2) {
  18. colorChange.push(parseInt("0x" + color.slice(i, i + 2)));
  19. }
  20. return "RGB(" + colorChange.join(",") + ")";
  21. } else {
  22. return color;
  23. }
  24. };

使用方法:

  1. "#fff".colorRgb(); // rgb(255,255,255)
  2. "#ffffff".colorRgb(); // rgb(255,255,255)

 

 

 

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多