2026年1月26日 星期一

初探 String.startsWith()

 初探 String.startsWith()

前言

  最近需要檢查字串開頭是否為特定的字串,結果發現官方有提供,也就是 String.startsWith() ,在此把學習的過程做個紀錄。


內容

  範例如下

let str = 'Hello World';
console.log( str.startsWith( 'Hello' ) );//true
console.log( str.startsWith( 'World' , 6 ) );//true


使用起來相當簡單,直接輸入要檢查的字串即可,另外還支援從指定位址檢查,如範例第二例所示。函式的名稱命名有點特別,是 startsWith ,而非 startWith ,注意 start 的後面要加 's' 。


參考資料

[ developer.mozilla.org ] String.prototype.startsWith()

2026年1月19日 星期一

初探 String.toWellFormed()

 初探 String.toWellFormed()

前言

  在先前的 初探 String.isWellFormed() 提到字串可以有不符合 UTF16 格式的字元,JavaScript 有提供 String.toWellFormed() 來消除不符合格式的字元,在此把學習的過程做個紀錄。


內容

  範例如下

console.log( 'Hello world \uD800');//Hello world �
//Followed will be error!
//console.log( encodeURI( 'Hello world \uD800') );
//
console.log( encodeURI( 'Hello world \uD800'.toWellFormed() ) );//Hello%20world%20%EF%BF%BD


如果字串裡含有非 UTF16 格式的字元可以正常顯示嗎?答案是可以的,不會報錯,該字元會用特別符號顯示,如範例第一例。既然可以正常顯示又有必要去除嗎?有些函式因為功能的關係,無法接受含有非 UTF16 格式的字元,如 [ developer.mozilla.org ] encodeURI() ,如果把含有非 UTF16 格式的字元輸入會直接報錯,這時就可以透過 String.toWellFormed() 來修正這個問題。


參考資料

[ developer.mozilla.org ] String.prototype.toWellFormed()

[ developer.mozilla.org ] encodeURI()


相關文章與資料

初探 String.isWellFormed()

2026年1月12日 星期一

初探 String.isWellFormed()

 初探 String.isWellFormed()

前言

  最近在 [ developer.mozilla.org ] String.prototype.isWellFormed() 看到 String.isWellFormed() ,這個函式的名稱直翻很難想到是在做什麼的,所以就點開看看,在此把學習的過程做個紀錄。


內容

  String.isWellFormed() 的功能是用來檢測字串是否是合法的 UTF-16 字串,UTF-16 字串是 JavaScript 的字串編碼格式,如果字串裡被插入不合 UTF-16 格式的字元,可以用 String.isWellFormed() 來確認,範例如下

console.log( 'Hello world'.isWellFormed() );//true
console.log( 'Hello world \uD800'.isWellFormed() );//false


第一例使用正常的字串,所以結果是 true ,第二例在結尾塞一個 \uD800 ,這是在 UTF-16 裡不會出現的字元,所以結果會傳回 false 。


參考資料

[ developer.mozilla.org ] String.prototype.isWellFormed()

2026年1月5日 星期一

關於 Uint8Array.setFromHex()

 關於 Uint8Array.setFromHex()

前言

  在閱覽 Uint8Array 的說明發現有 Uint8Array.setFromHex() ,抽空了解它的作用是什麼,在此把學習的過程做個紀錄。


內容

  範例如下

let str = '0123456789abcdef';
let arHex = Uint8Array.fromHex( str );
arHex.setFromHex( 'ff12' );
console.log( arHex.toHex() );//ff12456789abcdef
//
let arHex1 = Uint8Array.fromHex( 'ff' );
arHex1.setFromHex( '00ff' );
console.log( arHex1.toHex() );//00


Uint8Array.setFromHex() 是提供用字串的方式賦值,就像建構式用字串的方式來賦值,範例透過設置 'ff12' 來賦值,結果可以看到改變是從開頭賦值的,遺憾的是該函式不提供位移,只能從開頭賦值。如果超出賦值範圍會如何呢?因為 Uint8Array 是在建構的時候就確定了大小,如果用 Uint8Array.setFromHex() 超出賦值範圍,可以在範例的賦值 '00ff' 看到,可以成功賦值,不會報錯。


參考資料

[ developer.mozilla.org ] Uint8Array.prototype.setFromHex()


相關文章與資料

初探 Uint8Array.fromHex() 與 Uint8Array.toHex()

再探 Uint8Array.fromHex()

2025年12月29日 星期一

再探 Uint8Array.fromHex()

 再探 Uint8Array.fromHex()

前言

  在先前的 初探 Uint8Array.fromHex() 與 Uint8Array.toHex() 使用 Uint8Array.fromHex() 來編碼成 Hex ,Uint8Array.fromHex() 是如何編碼儲存的呢?在此把學習的過程做個紀錄。


內容

  在開始前先說明一下 初探 Uint8Array.fromHex() 與 Uint8Array.toHex() 會容易讓人以為可以將任何字串做編碼,但事實上只有符合 16 進制的字元( 0 ~ 9 與 a~f ) 可以被編碼,如果該字串含有非 16 進制的字元( 0 ~ 9 與 a~f ) 將會報錯。範例如下

let str = '0123456789abcdef';
let arHex = Uint8Array.fromHex( str);
console.log( arHex.toString() );//1,35,69,103,137,171,205,239
arHex.forEach( (val) => console.log( "0x"+val.toString(16).padStart(2,'0') ) );
// "0x01"
// "0x23"
// "0x45"
// "0x67"
// "0x89"
// "0xab"
// "0xcd"
// "0xef"


透過 Uint8Array.toString() 可以看到儲存的時候只有 8 個,但輸入的字串有 16 個,所以猜測是以每兩個 Byte 編碼成一個 Uint8 ,結果呢?沒錯,透過範例最後的 forEach() 可以看到每個 Uint8 編碼是來自兩個 Byte ,第一個 ox01 是來自原始字串的 o1 ,注意高位元是 0 ,低位元是 1 ,所以編碼成 0x01 ,而非0x10 。

 

參考資料

[ developer.mozilla.org ] Uint8Array.fromHex()


相關文章與資料

初探 Uint8Array.fromHex() 與 Uint8Array.toHex()

2025年12月22日 星期一

初探 Uint8Array.fromHex() 與 Uint8Array.toHex()

 初探 Uint8Array.fromHex() 與 Uint8Array.toHex()

前言

  JavaScript 提供透過 Uint8Array 轉換十六進制,那就是 Uint8Array.fromHex() 與 Uint8Array.toHex() ,在此把學習的過程做個紀錄。


內容

  範例如下

let str = '0123456789abcdef';
let arHex = Uint8Array.fromHex( str);
console.log( arHex.constructor.name );//Uint8Array
console.log( arHex.toString() );//1,35,69,103,137,171,205,239
console.log( arHex.toHex() );//0123456789abcdef


Uint8Array.fromHex() 與 Uint8Array.toHex() 的用法很簡單,透過 Uint8Array.fromHex() 來編碼,注意編碼完後的型別是 Uint8Array ,接著透過 toString() 印出編碼後的結果,要解碼透過 Uint8Array.toHex() 直接解碼即可。


參考資料

[ developer.mozilla.org ] Uint8Array.fromHex()

[ developer.mozilla.org ] Uint8Array.prototype.toHex()

2025年12月15日 星期一

注意 NaN 的型別

 注意 NaN 的型別

前言

  在先前的 注意 NaN 的比較 提到 NaN 的比較,這次來看 NaN 的型別,NaN 的型別有些特別,在此把學習的過程做個紀錄。


內容

  範例如下

console.log( typeof NaN );//Number
console.log( 1 + NaN );//NaN
console.log( NaN + 1 );//NaN
//
console.log( parseInt('A') );//NaN
console.log( parseFloat('A') );//NaN


NaN 的型別是 Number ,這有有點反直覺,因為 NaN 的全名是 Not A Number ,這有點特別!因為是型別是 Number ,所以可以搭配運算子運算,運算的規則很簡單,任何跟 NaN 運算的結果都會變成 NaN ,不論是後算 NaN 或 先算 NaN 都是一樣的結果。最後,不只是運算的過程會產生 NaN ,有些 Function 的結果也會回傳 NaN ,如 parseInt() 與 parseFloat() 。


參考資料

[ medium.com/andy-blog ] JavaScript 有趣的冷知識 :神奇的 NaN


相關文章與資料

初探 NaN

注意 NaN 的比較