問題:在一個固定長度的位置(例如標題欄),針對其內容的字數不定的情況下,如何實現總是能展示完整的標題? 解法: 1、定義獲取字元串位元組數的函數(註意是位元組數不是長度) 2、根據字元串位元組數調整字體大小(成反比,且可以使用Math.cos,具體根據實際情況來調整) String.prototype.b ...
問題:在一個固定長度的位置(例如標題欄),針對其內容的字數不定的情況下,如何實現總是能展示完整的標題?
解法:
1、定義獲取字元串位元組數的函數(註意是位元組數不是長度)
2、根據字元串位元組數調整字體大小(成反比,且可以使用Math.cos,具體根據實際情況來調整)
String.prototype.byteLength = function () { let bytesCount = 0; for (let i = 0, n = this.length; i < n; i += 1) { const c = this.charCodeAt(i); if ((c >= 0x0001 && c <= 0x007e) || (c >= 0xff60 && c <= 0xff9f)) { bytesCount += 1; } else { bytesCount += 2; } } return bytesCount; };