中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript中toFixed()和正則表達式的坑怎么解決

發布時間:2022-04-20 10:47:33 來源:億速云 閱讀:177 作者:iii 欄目:開發技術

本篇內容介紹了“JavaScript中toFixed()和正則表達式的坑怎么解決”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

toFixed精度問題

toFixed方法可以把Number四舍五入為指定小數位數的數字。可是大家看下下面這張圖,發現了什么?

JavaScript中toFixed()和正則表達式的坑怎么解決

0.985四舍五入之后變成了0.98!!

  • 這就是toFixed方法的坑。

導致原因

那這到底是怎么回事呢?本質其實是因為js小數的精度問題。 在計算機中計算,是將數字轉成二進制,進行計算之后再轉化為十進制。 比如將0.985轉化為二進制是0.1111110000101000(超出精度,結果保留了16位小數),此時再將該二進制轉化為十進制結果為:0.9849853515625,此時將他保留兩位小數就成了0.98

解決辦法

  • 那么要如何避免這種問題呢?可以用下面的方法來補充原生的toFixed方法

toFixed(number, precision) {
    var str = number + "";
    var len = str.length;
    var last = str.substring(len - 1, len);
    var afterPoint = str.substring(str.indexOf(".") + 1, len);
    if (last == "5" && afterPoint.length > precision) {
        last = "6";
        str = str.substring(0, len - 1) + last;
        return (str - 0).toFixed(precision);
    } else {
        return number.toFixed(precision);
    }
},

正則表達式全局匹配的坑

有這么一個需求,select支持可以搜索item。剛看到我就興致沖沖去寫了,這還不簡單嗎,輸入的數據和select中的數據源進行正則匹配,匹配到的就是搜索到的。

過濾函數我是這么寫的:

//searchKey是輸入的數據
const regex = new RegExp(searchKey.trim(), 'gi');
let dataSource = [
    {
        value: 'test1',
    },

    {
        value: 'test2',
    },
];
let res = dataSource
    .map((i) => {
            let _flag = regex.test(i.value);
            i.visible = _flag;
            return i;
    })
    .filter((i) => i.visible);

但是實際運行時,發現數據源中的數據,有的可以匹配到有的匹配不到。當時就納悶了,這有什么問題嗎?最后幾經查找答案,原來是正則表達式的全局匹配有個坑:正則表達式中有一個lastIndex的屬性,這個屬性表示上一次匹配文本結果之后的第一個字符的位置。他在下一次查找的時候,會從lastIndex往后繼續查找,這就會導致一下個匹配返回false。

那么如何解決呢?

因為lastIndex屬性是可讀可寫的,所以我這里的解決辦法是每次test方法之后將將lastIndex置為零,這樣每次匹配都將會從最開始進行查找。這樣就會避免這個問題了哦!

let _flag = regex.test(i.value);
regex.lastIndex = 0;

“JavaScript中toFixed()和正則表達式的坑怎么解決”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

贵南县| 台东市| 浦北县| 南开区| 清远市| 平和县| 厦门市| 买车| 咸宁市| 旬阳县| 淳化县| 镇平县| 新巴尔虎右旗| 佛学| 巨野县| 稻城县| 滦平县| 东港市| 江山市| 杭州市| 浦城县| 吴江市| 上犹县| 达日县| 鄂伦春自治旗| 新兴县| 巩义市| 孙吴县| 四子王旗| 博野县| 扶余县| 驻马店市| 济源市| 长春市| 元江| 宜君县| 桐梓县| 东山县| 大方县| 克东县| 汝州市|