2024年9月30日 星期一

複製 Intl.ListFormat 的參數

 複製 Intl.ListFormat 的參數

前言

  Intl.ListFormat 參數可以跟 複製 Intl.NumberFormat 的參數 一樣複製參數嗎?答案是可以的,且用法還是一樣的!在此把學習的過程做個紀錄。


內容

  範例如下

let listFormat = new Intl.ListFormat('zh-TW', {
  style: 'long',
  type: 'conjunction',
} );
//
let options = listFormat.resolvedOptions();
//
console.log( options.locale);//zh-TW
console.log( options.style);//long
console.log( options.type);//conjunction


要複製參數依舊透過 resolvedOptions() 來取得,回傳值會有各個參數,直接對該值取得即可,用法與 Intl.NumberFormat 的使用是一樣的。


參考資料

[ developer.mozilla.org ] Intl.ListFormat


相關文章與資料

複製 Intl.NumberFormat 的參數

2024年9月23日 星期一

再探 Intl.ListFormat()

 再探 Intl.ListFormat()

前言

  在先前的 初探 Intl.ListFormat() 介紹了使用各種 type 後的結果差異,會引響結果的參數還有 style ,在此把學習的過程做個紀錄。


內容

  範例如下

const itemList = ['A', 'B', 'C' , 'D' ];
//
console.log( new Intl.ListFormat('zh-TW', {
  style: 'long',
  type: 'conjunction',
}).format(itemList) );//A、B、C和D
//
console.log( new Intl.ListFormat('zh-TW', {
  style: 'short',
  type: 'conjunction',
}).format(itemList) );//A、B、C和D
//
console.log( new Intl.ListFormat('zh-TW', {
  style: 'narrow',
  type: 'conjunction',
}).format(itemList) );//A、B、C和D
//
console.log( new Intl.ListFormat('en', {
  style: 'long',
  type: 'conjunction',
}).format(itemList) );//A, B, C, and D
//
console.log( new Intl.ListFormat('en', {
  style: 'short',
  type: 'conjunction',
}).format(itemList) );//A, B, C, & D
//
console.log( new Intl.ListFormat('en', {
  style: 'narrow',
  type: 'conjunction',
}).format(itemList) );//A, B, C, D
//
console.log( new Intl.ListFormat('en', {
  style: 'long',
  type: 'unit',
}).format(itemList) );//A, B, C, D


這次調整 style 的參數,可以是 long 、 short 與 narrow ,預設是 long ,範例的地區使用 zh-TW 時發現這三種參數結果是一樣的!但當地區改成 en 後,結果就有差異 ,使用 short 後會發現 and 會被戴換成 & ,使用 narrow 後更是發現連 and 都不見了!結果會和把 type 輸入 unit 的結果一樣,也就是說當 type 是 conjuction 時不一定都會顯示 and ,還要看 style 與地區的參數才能決定是否有 and。 


參考資料

[ developer.mozilla.org ] Intl.ListFormat


相關文章與資料

初探 Intl.ListFormat()

2024年9月16日 星期一

初探 Intl.ListFormat.formatToParts()

 初探 Intl.ListFormat.formatToParts()

前言

  在先前的 初探 Intl.ListFormat() 使用 Intl.ListFormat.format() 來輸出結果,Intl.ListFormat 還支援另一種輸出,也就是 Intl.ListFormat.formatToParts() ,在此把學習的過程做個紀錄。


內容

  範例如下

const itemList = ['A', 'B', 'C' , 'D' ];
//
let parts = new Intl.ListFormat('en', {
  style: 'long',
  type: 'conjunction',
}).formatToParts(itemList);
console.log(parts);
// [[object Object] {
//   type: "element",
//   value: "A"
// }, [object Object] {
//   type: "literal",
//   value: ", "
// }, [object Object] {
//   type: "element",
//   value: "B"
// }, [object Object] {
//   type: "literal",
//   value: ", "
// }, [object Object] {
//   type: "element",
//   value: "C"
// }, [object Object] {
//   type: "literal",
//   value: ", and "
// }, [object Object] {
//   type: "element",
//   value: "D"
// }]
partValues = parts.map((p) => p.value);
console.log(partValues);//["A", ", ", "B", ", ", "C", ", and ", "D"]


Intl.ListFormat.formatToParts() 的功用和之前的 初探 Intl.NumberFormat.formatToParts() 差不多,都是把結果切成很多的物件,如同範例的 parts 一樣,如果要提取每個物件的 value 的話,透過 Array.map()  就可以輸出包含每個 value 的陣列。

 

參考資料

[ developer.mozilla.org ] Intl.ListFormat.formatToParts()


相關文章與資料

初探 Intl.ListFormat()

初探 Intl.NumberFormat.formatToParts()

2024年9月9日 星期一

初探 Intl.ListFormat()

 初探 Intl.ListFormat()

前言

  在書寫文章時,有多個選項時會書寫成"A、B與C"這項的格式 ,Intl.ListFormat() 可以依據不同的地區提供此格式,在此把學習過程做個紀錄。


內容

  範例如下

const itemList = ['A', 'B', 'C' , 'D' ];

console.log( new Intl.ListFormat('en', {
  style: 'long',
  type: 'conjunction',
}).format(itemList) );//A, B, C, and D
//
console.log( new Intl.ListFormat('zh-TW', {
  style: 'long',
  type: 'conjunction',
}).format(itemList) );//A、B、C和D
//
console.log( new Intl.ListFormat('zh-TW', {
  style: 'long',
  type: 'disjunction',
}).format(itemList) );//A、B、C或D
//
console.log( new Intl.ListFormat('zh-TW', {
  style: 'long',
  type: 'unit',
}).format(itemList) );//A B C D


Intl.ListFormat() 是用來顯示陣列的內容,讓內容可以符合當地的文法書寫,第一例顯示是以 en 來示範,可以看到顯示的結果是 A, B, C, and D ,最後兩個項目會插入一個 and ,接著把區域改成 zh-TW 得到的結果是 A、B、C 和 D ,最後兩個選項會插入"和",選項間的符號也變成 、  ,參數的 type 還可以是 disjunction 與 unit ,當輸入 disjunction  後,最後兩個項目插入會變成"或",當樹入 unit ,最後兩個選項就不再插入字,項目間會是用"空白"隔開,可以理解就只是單純的個別顯示。


參考資料

[ developer.mozilla.org ] Intl.ListFormat

2024年9月2日 星期一

調整 Intl 的數字系統

 調整 Intl 的數字系統

前言

  Intl 可以調整數字系統,在此把學習的過程做個紀錄'。


內容

  範例如下

console.log( new Intl.NumberFormat('zh-TW', { 
  style: 'unit', 
  unit : 'liter',
  unitDisplay : 'long',
  numberingSystem : 'arab',
  }).format( 1234567890) );//١٬٢٣٤٬٥٦٧٬٨٩٠ 公升
//
console.log( new Intl.NumberFormat('zh-TW', { 
  style: 'unit', 
  unit : 'liter',
  unitDisplay : 'long',
  numberingSystem : 'hans',
  }).format( 1234567890) );//1,234,567,890 公升
//
console.log( new Intl.NumberFormat('zh-TW', { 
  style: 'unit', 
  unit : 'liter',
  unitDisplay : 'long',
  numberingSystem : 'mathsans',
  }).format( 1234567890) );//𝟣,𝟤𝟥𝟦,𝟧𝟨𝟩,𝟪𝟫𝟢 公升
//follow can't work in Chrome
//console.log( Intl.Locale.prototype.getNumberingSystems() );


  要改變數字系統是透過 numberingSystem ,能夠填的參數可以在 Intl.Locale.prototype.getNumberingSystems() ,根據區域會有自己的預設值, zh-TW 的預設值是 hans ,範例的第一例顯示的是"阿拉伯-印度數字",明顯的不是我們常見的數字,第三的範例看起來和 hans 一樣,但要注意數字 0 顯示得字型式不一樣的!最後的 Intl.Locale.prototype.getNumberingSystem() 被註解掉是因為它並不是每個瀏覽器都支援,至少我使用的 Chrome 目前並不支援,該作用應該是取得預設的數字系統參數,似乎真沒必要提供,因為地區本身就會有慣用的數字系統參數了,會要改的時候應該是要以非慣用的數字系統顯示才會用到,所以只要知道該地區的預設值是什麼就可以了,不能用函數詢問也沒差。


參考資料

[ developer.mozilla.org ] Intl.NumberFormat

Intl.Locale.prototype.getNumberingSystems()