欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于json-bigint處理大數(shù)字問題

 更新時間:2024年05月23日 17:10:02   作者:flyyy菜鳥  
這篇文章主要介紹了關(guān)于json-bigint處理大數(shù)字問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

json-bigint處理大數(shù)字問題

js里面的整數(shù)有安全范圍,即最大能顯示的范圍,超過了這個范圍可能會精度丟失

Number.MAX_SAFE_INTEGER  //值為9007199254740991

json-bigint:可以像JSON.parse一樣方便轉(zhuǎn)換

用法:

//導(dǎo)入
import JSONbig from 'json-bigint'

//可以通過axios的transformResponse方法,這個方法的作用是在傳遞給then/catch前,允許修改響應(yīng)數(shù)據(jù)

//axios在這里默認(rèn)把響應(yīng)體從json字符串轉(zhuǎn)成了js對象
axios.defaults.transformResponse = [function (data) {
console.log(data)//這里的data是字符串,在這個字符串的是沒有丟失精度的,所以需要在這里先把精度調(diào)好

	try {
	//作用1:把json字符串轉(zhuǎn)為js對象
	//作用2:把里面的大數(shù)字做安全處理
	 return JSONbig.parse(data)
	}catch(){
	return data;
	}
	//return data;
}]

//如果不寫這個方法,返回的數(shù)據(jù)是自動就轉(zhuǎn)為json對象的了,如果寫了,就要自己轉(zhuǎn)為對象,即return JSON.parse(data)

注意:

alert會自動調(diào)用了toString()方法

只要經(jīng)過json-bigint轉(zhuǎn)換后的id,直接toString(),就能得到真實的id

超大整型數(shù)字處理json-bigint的應(yīng)用

1.json-bigint的作用和原理

json-bigint的作用:

項目中如果使用一些超出javascript語言限制的超大整型數(shù)字信息,該數(shù)字會變形為其他信息,為了避免產(chǎn)生問題,可以通過json-bigint做轉(zhuǎn)換,使得超大整型數(shù)字可以正常使用,這就是json-bigint的作用。

情景:

  • 后端服務(wù)器返回的文章id已經(jīng)大大超過了js語言可以表達的最大整型范疇,因而直接使用的時候會發(fā)生變型:

例如:

  • 本質(zhì)id為:1215831343376629760
  • 變型后為:1215831343376629800
console.log(1215831343376629760)    // 輸出為:1215831343376629800
  • javascript中可以表達的最大整型可以通過如下代碼獲得:
console.log( Number.MAX_SAFE_INTEGER )
// 輸出:9007199254740991

json-bigint的原理:

json-bigint會把超大整型的數(shù)字信息,拆分為小段信息存儲到數(shù)組的各個元素中,待使用的時候再拼接到一起變?yōu)樽址?/p>

github網(wǎng)站相關(guān)介紹: https://github.com/sidorares/json-bigint

json-bigint使用示例:

var JSONBig = require('json-bigint');  // 需要先安裝 npm i json-bigint
var str = '{ "value" : 9223372036854775807, "v2": 123 }';

var obj = JSONBig.parse(str) // 字符串--->對象
console.log(obj.value) // 9223372036854775807(正確)

var obj2 = JSON.parse(str) // 字符串--->對象
console.log(obj2.value) // 9223372036854776000(錯誤)

結(jié)論:

  • json-bigint會對一個包含超大整型信息的“字符串”做轉(zhuǎn)換處理變?yōu)閷ο?,這個對象可以獲得正確的超大整型數(shù)字信息。

2.超大整型數(shù)字的具體處理

示例:

  • 應(yīng)用超大整型數(shù)字處理技術(shù)對接口返回的文章id信息做處理,使得可以被正確接收和使用。

  • 服務(wù)器給客戶端返回數(shù)據(jù)的第一手處理者是 “轉(zhuǎn)換器( transformResponse )”,轉(zhuǎn)換器處理完畢再交給響應(yīng)攔截器使用,故要對超大整型數(shù)字信息做處理,下手點是"轉(zhuǎn)換器"(響應(yīng)攔截器獲得數(shù)據(jù)已經(jīng)是變形后的內(nèi)容了)

本質(zhì)上:服務(wù)器返回信息的類型是“字符串”,要經(jīng)過轉(zhuǎn)換器做JSONbig.parse()轉(zhuǎn)化處理,所以響應(yīng)攔截器接收到的是對象。

步驟:

1.安裝工具依賴包:

npm i json-bigint

2.在src/utils/ax.js中引入json-bigint模塊,對服務(wù)器返回的信息做處理,具體通過axios的 “數(shù)據(jù)轉(zhuǎn)換” 機制實現(xiàn):

import JSONbig from 'json-bigint'

// 服務(wù)器端返回,數(shù)據(jù)轉(zhuǎn)換器,應(yīng)用
axios.defaults.transformResponse = [function (data) {
  // data的返回形式有兩種
  // 1. 實體字符串
  // 2. 空字符串(不能轉(zhuǎn)的)
  // JSONbig.parse針對超大整型進行處理,其他信息不給處理
  if (data) {
    return JSONbig.parse(data)
  }
  return data
}]

注意:

1.上述數(shù)據(jù)轉(zhuǎn)換一定要設(shè)置else,以便對空字符串做處理,因為服務(wù)器有時候會返回空字符串信息。

2. json-bigint處理的是字符串類型的信息,超大整型數(shù)字給處理,普通信息不給與處理。

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 在Vue.js應(yīng)用中實現(xiàn)分布式搜索和全文搜索

    在Vue.js應(yīng)用中實現(xiàn)分布式搜索和全文搜索

    分布式搜索和全文搜索在現(xiàn)代應(yīng)用程序中變得越來越重要,因為它們可以幫助用戶快速查找和檢索大量數(shù)據(jù),Elasticsearch是一種強大的分布式搜索引擎,本文將介紹如何在Vue.js應(yīng)用程序中實現(xiàn)分布式搜索和全文搜索,以及如何與Elasticsearch集成,需要的朋友可以參考下
    2023-11-11
  • 深入理解Vue.js源碼之事件機制

    深入理解Vue.js源碼之事件機制

    本篇文章主要介紹了Vue.js源碼之事件機制,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • vue實現(xiàn)點擊出現(xiàn)操作彈出框的示例

    vue實現(xiàn)點擊出現(xiàn)操作彈出框的示例

    這篇文章主要介紹了vue實現(xiàn)點擊出現(xiàn)操作彈出框的示例,幫助大家更好的理解和使用vue,感興趣的朋友可以了解下
    2020-11-11
  • Vue3組件不發(fā)生變化如何監(jiān)聽pinia中數(shù)據(jù)變化

    Vue3組件不發(fā)生變化如何監(jiān)聽pinia中數(shù)據(jù)變化

    這篇文章主要給大家介紹了關(guān)于Vue3組件不發(fā)生變化如何監(jiān)聽pinia中數(shù)據(jù)變化的相關(guān)資料,pinia是Vue的存儲庫,它允許您跨組件/頁面共享狀態(tài),文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-11-11
  • 如何利用vue3實現(xiàn)放大鏡效果實例詳解

    如何利用vue3實現(xiàn)放大鏡效果實例詳解

    最近有項目需要用到對圖片進行局部放大,類似淘寶商品頁的放大鏡效果,經(jīng)過一番研究功能可用,下面這篇文章主要給大家介紹了關(guān)于如何利用vue3實現(xiàn)放大鏡效果的相關(guān)資料,需要的朋友可以參考下
    2021-09-09
  • 前端報錯npm ERR! cb() never called!問題解決辦法

    前端報錯npm ERR! cb() never called!問題解決辦法

    最近接手了一個前臺項目,執(zhí)行npm install的時候一直報錯,所以這里就給大家總結(jié)下,這篇文章主要給給大家介紹了關(guān)于前端報錯npm?ERR! cb() never called!問題的解決辦法,需要的朋友可以參考下
    2024-05-05
  • vue源碼學(xué)習(xí)之Object.defineProperty對象屬性監(jiān)聽

    vue源碼學(xué)習(xí)之Object.defineProperty對象屬性監(jiān)聽

    這篇文章主要介紹了vue源碼學(xué)習(xí)之Object.defineProperty對象屬性監(jiān)聽,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • Vue打包后不同版本詳細(xì)解析

    Vue打包后不同版本詳細(xì)解析

    vue項目打包是我們?nèi)粘=?jīng)常遇到的,下面這篇文章主要給大家介紹了關(guān)于Vue打包后不同版本詳細(xì)解析的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2022-12-12
  • 寫一個Vue Popup組件

    寫一個Vue Popup組件

    這篇文章主要介紹了寫一個Vue Popup組件,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-02-02
  • vue+antDesign實現(xiàn)樹形數(shù)據(jù)展示及勾選聯(lián)動

    vue+antDesign實現(xiàn)樹形數(shù)據(jù)展示及勾選聯(lián)動

    本文主要介紹了vue+antDesign實現(xiàn)樹形數(shù)據(jù)展示及勾選聯(lián)動,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02

最新評論