亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

詳解JavaScript中的強制類型轉換

2024-05-06 16:49:56
字體:
來源:轉載
供稿:網友

JavaScript 原語

JavaScript 建立在一系列基本單元之上。你應該對其中的一些已經很熟悉了,比如字符串和數字:

var greet = "Hello";var year = 89;

字符串和數字是該語言所謂“原語”的一部分。完整清單是:

  1. String
  2. Number
  3. Boolean
  4. Null
  5. Undefined
  6. Object
  7. Symbol (ES6中添加,此處不予介紹)

布爾值用來表示可能是真或假的值。 null 是故意不去賦值,它通常被分配給一個變量,用于表示綁定完畢,稍后將填充有意義的內容。

var maybe = null;

然后才是 undefined,這意味著變量仍然沒有被附加上:

var name;console.log(name)undefined

null 和 undefined 看起來非常相似,但它們是兩個截然不同的實體,很多開發人員仍然不確定應該使用哪個。

如果要判斷 JavaScript 實例的類型,可以用 typeof 運算符。讓我們用字符串嘗試一下:

typeof "alex"> "string"

還有數字:

typeof 9> "number"

用于布爾值:

typeof false> "boolean"

undefined:

typeof undefined> "undefined"

還有 null:

typeof null> "object"

結果令人驚訝! null 看起來像一個對象,但實際上它是 JavaScript 中的一個歷史性錯誤,自語言誕生就躺在那里了。 由于這些問題,JavaScript 一直聲名狼借。但這僅僅是個開始。

陌生的事情

在 JavaScript 中,在兩種類型之間進行轉換時有一些奇怪的規則。讓我給你一些背景信息。先用 Python 舉一個例子。 在 Python 中執行以下指令:

'hello' + 89

會給你一個明確的錯誤:

TypeError: can only concatenate str (**not** "int") to str

而在 JavaScript 中,只有天空才是你的極限:

'hello' + 89

事實上給出:

"hello89"

 如果我們嘗試向字符串添加數組,看起來會更加奇怪:

'hello' + []

將會得到

 'hello'

 還有

'hello' + [89]

 會給你一個驚喜:

 "hello89"

 看起來這種轉換背后存在某種邏輯。它甚至適用于存在更多元素的 array :

'hello' + [89, 150.156, 'mike']

得到:

"hello89,150.156,mike"

 這兩行 JavaScript 足以讓 Java 程序員逃離。但是這種行為在 JavaScript 中 100% 是又意義的。因此這種隱式轉換,也稱為強制類型轉換是非常值得探索的。

當一個數字變成一個字符串

一些編程語言有一個叫做類型轉換的概念,這意味著:如果我想把一個數字或實例轉換為另一種類型,那么我必須使顯式轉換。它也適用于 JavaScript。請看以下示例:

var greet = "Hello";var year = 89;

如果我想明確的進行轉換,可以在代碼中表明意圖:

var greet = "Hello";var year = 89;var yearString = year.toString()

要么這樣做:

var greet = "Hello";var year = 89;var yearString = String(year)

然后我可以連接兩個變量:

greet + yearString;

 但是在 JavaScript 中有一種被稱為隱式轉換的微妙機制,由 JavaScript 引擎提供。該語言不會阻止我們對數字和字符串進行加法操作:

'hello' + 89

會得到:

"hello89"

 但是這種轉換背后的邏輯是什么?你可能會驚訝地發現 JavaScript 中的加法運算符 + 會自動將兩個操作數中的任何一個都轉換為字符串,如果其中至少有一個是字符串的話!

你會發現更令人驚訝的是,這條規則在ECMAScript規范中一脈相承。 第11.6.1節 定義了加法運算符的行為,我在這里為你做了總結:

如果 x 是 String 或 y 是String,則返回 ToString(x),然后返回ToString(y)

這個花招只適用于數字嗎?并不是。 數組和對象也會受到相同的轉換:

'hello' + [89, 150.156, 'mike']

會得到:

"hello89,150.156,mike"

 那么下面的代碼會得到怎樣的結果:

'hello' + { name: "Jacopo" }

要找到答案,你可以通過將對象轉換為字符串來進行快速測試:

String({ name: "Jacopo" })

將會得到:

"[object Object]"

 所以我有一種感覺:

'hello' + { name: "Jacopo" }

會得到:

"hello[object Object]"

 打住!這又是什么?

JavaScript 中 [object Object] 的含義是什么?
“[object Object]” 是最常見的 JavaScript “怪癖”之一。

幾乎每個 JavaScript 實例都有一個名為 toString() 的方法,有些方法是由 Object.prototype.toString 提供的。
某些類型(如數組)實現了 toString() 的自定義版本,以便在調用方法時將值轉換為字符串。例如 Array.prototype.toString 會覆蓋 Object.toString()(也稱為 method shadowing)。

但是當你在普通的 JavaScript 對象上調用 toString() 時,引擎會給出“[object Object]”,因為 Object.toString() 的默認行為是由實體類型(在這種情況下為Object)返回字符串 object 。

現在讓我們把注意力集中在 JavaScript 比較運算符上,它們與算術運算符一樣奇怪。

等于還是不等于?

JavaScript 中有兩個主要的比較運算符。

第一個我們稱之為“弱比較”。這是抽象比較運算符(雙等號):==。

另一個是“強比較”,可以通過三等號進行識別:=== 也稱為嚴格比較運算符。它們兩者的行為方式完全不同。

來看一些例子。首先,如果我們將兩個字符串與兩個運算符進行比較,我們得到相同的結果

"hello" == "hello"
> true
"hello" === "hello"
> true

 看上去一切都還好。

現在嘗試比較兩種不同的類型,數字和字符串。首先是“強比較”:

"1" === 1false

這說得通!字符串“1”與數字1是不同的。但是“弱比較”會發生什么?

"1" == 1 true

居然是true!它沒有任何意義,除非這種行為與我們之前看到的隱式轉換有關。

如果適用相同的規則怎么辦?沒錯! ECMAScript spec 再次罷工。結果抽象比較運算符在比較它們之前在類型之間進行自動轉換。這是規范的摘要:

比較 x == y 執行如下:
如果 x 是 String 且 y 是Number,則返回比較結果 ToNumber(x)== y
規范說:如果第一個操作數是一個字符串,第二個操作數是一個數字,那么將第一個操作數轉換為數字。有趣。

JavaScript 規范充滿了這個瘋狂的規則,我強烈鼓勵大家對它深入挖掘。

在此期間除非你有充分的理由否則在 JavaScript 代碼中避免使用抽象比較運算符。你以后會感謝自己的。

那么“強勢比較”怎么樣?規范中的說 嚴格相等比較在把值與三等 === 進行比較之前沒有進行自動轉換。在代碼中使用嚴格相等比較可以避免愚蠢的 bug。

總結

JavaScript 中有七個構建塊,即 String,Number,Boolean,Null,Undefined,Object 和 Symbol。這些類型被稱為基元。

JavaScript 開發人員可以使用算術和比較運算符來操作這些類型。但是我們要特別注意加法運算符 + 和抽象比較運算符 ==,它本質上傾向于在類型之間進行轉換。

以上所述是小編給大家介紹的JavaScript中的強制類型轉換詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97香蕉超级碰碰久久免费的优势| 亚洲精品aⅴ中文字幕乱码| 亚洲国产日韩欧美综合久久| 欧美夫妻性视频| 亚洲精品小视频| 97在线视频一区| 亚洲一区二区三区四区在线播放| 美女视频久久黄| 亚洲最大福利网| 亚洲肉体裸体xxxx137| 日韩欧美精品中文字幕| 国产精品久久久久久超碰| 日本精品视频在线播放| 最近2019年手机中文字幕| 91久久久久久久久| 色www亚洲国产张柏芝| 久久五月天色综合| 国产成人精品在线观看| 国产精品一区二区久久久久| 欧美成人手机在线| 日本精品久久电影| www.久久久久久.com| 亚洲v日韩v综合v精品v| 国产精品成人va在线观看| 日韩av片电影专区| 国产精品一区二区三区毛片淫片| 热久久免费国产视频| 91av在线播放| 国产精品丝袜久久久久久高清| 日本一区二区在线免费播放| 欧美日韩国产成人| 成人97在线观看视频| 国产精品视频公开费视频| 国产精品高清网站| 亚洲精品网站在线播放gif| 少妇av一区二区三区| 在线观看日韩视频| 欧美交受高潮1| 91午夜理伦私人影院| 久久99国产综合精品女同| 国产欧美精品一区二区三区-老狼| 国产精品美女免费| 欧美激情一区二区三区成人| 九九热99久久久国产盗摄| 亚洲一区二区少妇| 亚洲欧美国产精品| 欧美激情视频三区| 在线播放精品一区二区三区| 在线成人激情黄色| 久久99亚洲热视| 一区二区三区四区在线观看视频| 一区二区三区国产在线观看| 亚洲白虎美女被爆操| 亚洲在线观看视频| 精品视频9999| 欧美成人精品在线视频| 久久久久久久久综合| 欧洲成人在线视频| 欧美激情精品久久久久久黑人| 亚洲男人天堂网| 久久亚洲电影天堂| 欧美二区在线播放| 欧美一区二区三区艳史| 91美女片黄在线观看游戏| 欧美日本精品在线| 国产精品久久激情| 国产日韩av高清| 国产成人jvid在线播放| 欧美成人h版在线观看| 高清日韩电视剧大全免费播放在线观看| 日韩在线观看成人| 精品视频久久久久久| 久久av.com| 综合网中文字幕| 亚洲一级免费视频| 久久久久久久一区二区三区| 国产一区二区三区视频在线观看| 国产成人在线一区| 欧美成人精品不卡视频在线观看| 欧美激情免费看| 日韩欧美黄色动漫| 欧美性xxxx在线播放| 久久香蕉国产线看观看网| 97超碰色婷婷| 欧美激情综合色综合啪啪五月| 2019日本中文字幕| 国产精品三级久久久久久电影| 欧美日韩成人在线播放| 中文字幕日韩欧美在线| 精品视频一区在线视频| 亚洲精品一区中文字幕乱码| 欧美老少做受xxxx高潮| 亚洲人成网站777色婷婷| 国模精品视频一区二区三区| 尤物精品国产第一福利三区| 国产精品视频公开费视频| 国产成人高潮免费观看精品| 91在线免费视频| 亚洲第一页自拍| 欧洲亚洲妇女av| 91免费高清视频| 亚洲成人精品视频| 欧美一性一乱一交一视频| 日本久久久久久| 欧美激情手机在线视频| 日韩中文理论片| 成人免费在线视频网站| 国产乱人伦真实精品视频| 在线电影av不卡网址| 中文字幕在线看视频国产欧美在线看完整| 亚洲女在线观看| 亚洲激情视频网站| 久久久久久12| 亚洲精品v欧美精品v日韩精品| 午夜精品一区二区三区av| 91社区国产高清| 亚洲国产高潮在线观看| 国内精品免费午夜毛片| 亚洲美女av在线播放| 国产狼人综合免费视频| 国产欧美亚洲视频| 亚洲视频一区二区| 国产自产女人91一区在线观看| 国产亚洲欧洲高清一区| 成人国内精品久久久久一区| 亚洲精品欧美一区二区三区| 亚洲精品在线91| 国产精品久久久久久久久久久久| 国产精品久久国产精品99gif| 亚洲va欧美va国产综合久久| 欧美性理论片在线观看片免费| 欧美国产亚洲视频| 亚洲精品第一国产综合精品| 久久999免费视频| 日韩电影在线观看免费| 欧美性xxxx极品hd欧美风情| 国产精品免费视频xxxx| 久久91精品国产91久久跳| 欧美激情小视频| 日韩三级影视基地| 欧美激情视频播放| 91高清视频免费| 国内精品久久久久久中文字幕| 91精品国产91久久久| 日韩经典中文字幕在线观看| 国产欧美日韩中文字幕| 91色视频在线观看| 有码中文亚洲精品| 久久五月天色综合| 亚洲精品av在线| 亚洲综合视频1区| 这里只有精品在线播放| 国产成人精品一区二区| 国产91精品视频在线观看| 一区二区三区国产视频| 精品中文字幕乱| 在线精品播放av| 日韩中文字在线| 亚洲国产成人精品一区二区| 日韩中文av在线| 中文字幕视频一区二区在线有码| 国产欧美一区二区三区在线| 国产成人高潮免费观看精品| 久久91亚洲人成电影网站|