搜尋
首頁web前端js教程js隱式類型轉換使用步驟詳解

js隱式類型轉換使用步驟詳解

May 24, 2018 pm 02:17 PM
javascript使用步驟

這次帶給大家js隱式類型轉換使用步驟詳解,js隱式類型轉換使用的注意事項有哪些,下面就是實戰案例,一起來看一下。

相信剛開始了解js的時候,都會遇到 2 =='2',但 1 2 == 1 '2'為false的情況。這時候應該會是一臉懵逼的狀態,不得不感慨js弱類型的靈活讓人髮指,隱式類型轉換就是這麼猝不及防。結合實際的情況來看,有意或無意中涉及隱式類型轉換的情況還是很多的。既然要用到,就需要掌握其原理,知其然重要知其所以然更重要。

js的變數型別

JavaScript 是弱型別語言,表示JavaScript 變數沒有預先決定的型別。   
且變數的型別是其值的型別。也就是說變數目前的型別由其值決定,誇張點說上一秒種的string,下一秒可能就是個array了。另外當進行某些操作時,變數可以進行型別轉換,我們主動進行的就是顯式型別轉換,另一種就是隱式型別轉換了。例如:

var a = '1';   
typeof a;//string 
a =parseInt(a); //显示转换为number
typeof a  //number   
a == '1' //true

弱類型的特性在帶給我們便利的同時,也會帶給我們困擾。趨利避害,充分利用這個特性的前提就是掌握類型轉換的原理,下面一起看一下。

js資料型別

老生常談的兩大類別資料型別:

  1. 原始型別   
    Undefined、 Null、 String、 Number、 Boolean

  2. 引用類型 
    object

此外還有一個es6新增的Symbol,先不討論它。對於這五類原始類型,突然提問可能想不全,沒必要去死記硬背,可以想一下為否的常見變數及其對應值即可。

0 Number
#'' String
false Boolean
#null Null
undefined Undefined

对于不同的数据格式转换规则是不同的,我们需要分别对待。

转换规则

既然是规范定义的规则,那就不要问为什么了,先大致看一下,争取记住。是在不行经常翻翻看看大佬的博客es5规范。转换有下面这么几类,我们分别看一下具体规范。(这部分转换规则,完全可以跳过去,看到下面的实例再回头看应该更容易接受一些)

  • 转换为原始值

  • 转换为数字

  • 转换为字符串

ToPrimitive(转换为原始值)

ToPrimitive 运算符接受一个值,和一个可选的 期望类型 作参数。ToPrimitive 运算符把其值参数转换为非对象类型。如果对象有能力被转换为不止一种原语类型,可以使用可选的 期望类型 来暗示那个类型。根据下表完成转换

js隱式類型轉換使用步驟詳解

这段定义看起来有点枯燥。转换为原始值,其实就是针对引用数据的,其目的是转换为非对象类型。  
如果已经是原始类型,当然就不做处理了  
对于object,返回对应的原始类型,该原始类型是由期望类型决定的,期望类型其实就是我们传递的type。直接看下面比较清楚。  
ToPrimitive方法大概长这么个样子具体如下。

/**
* @obj 需要转换的对象
* @type 期望转换为的原始数据类型,可选
*/
ToPrimitive(obj,type)

type可以为number或者string,两者的执行顺序有一些差别  
string:

  1. 调用obj的toString方法,如果为原始值,则返回,否则下一步

  2. 调用obj的valueOf方法,后续同上

  3. 抛出TypeError 异常

number:

  1. 调用obj的valueOf方法,如果为原始值,则返回,否则下一步

  2. 调用obj的toString方法,后续同上

  3. 抛出TypeError 异常

其实就是调用方法先后,毕竟期望数据类型不同,如果是string当然优先调用toString。反之亦然。  
当然type参数可以为空,这时候type的默认值会按照下面的规则设置

  1. 该对象为Date,则type被设置为String

  2. 否则,type被设置为Number

对于Date数据类型,我们更多期望获得的是其转为时间后的字符串,而非毫秒值,如果为number,则会取到对应的毫秒值,显然字符串使用更多。
其他类型对象按照取值的类型操作即可。

概括而言,ToPrimitive转成何种原始类型,取决于type,type参数可选,若指定,则按照指定类型转换,若不指定,默认根据实用情况分两种情况,Date为string,其余对象为number。那么什么时候会指定type类型呢,那就要看下面两种转换方式了。

toNumber

某些特定情况下需要用到ToNumber方法来转成number
运算符根据下表将其参数转换为数值类型的值
js隱式類型轉換使用步驟詳解

对于string类型,情况比较多,只要掌握常见的就行了。和直接调用Number(str)的结果一致,这里就不多提了,主要是太多提不完。  
需要注意的是,这里调用ToPrimitive的时候,type就指定为number了。下面的toString则为string。

toString

ToString 运算符根据下表将其参数转换为字符串类型的值:  
其实了解也很简单,毕竟是个规范,借用大佬一张图:

js隱式類型轉換使用步驟詳解

虽然是需要死记的东西,还是有些规律可循的。
对于原始值:

  • Undefined,null,boolean
    直接加上引号,例如'null'

  • number 则有比较长的规范,毕竟范围比较大  
    常见的就是 '1'   NaN则为'NaN'  基本等同于上面一条
    对于负数,则返回-+字符串 例如 '-2'  其他的先不考虑了。

  • 对象则是先转为原始值,再按照上面的步骤进行处理。

valueOf

当调用 valueOf 方法,采用如下步骤:

  1. 调用ToObject方法得到一个对象O

  2. 原始数据类型转换为对应的内置对象, 引用类型则不变

  3. 调用该对象(O)内置valueOf方法.

不同内置对象的valueOf实现:

  • String => 返回字符串值

  • Number => 返回数字值

  • Date => 返回一个数字,即时间值,字符串中内容是依赖于具体实现的

  • Boolean => 返回Boolean的this值

  • Object => 返回this

对照代码更清晰一点

var str = new String('123')
//123
console.log(str.valueOf())
var num = new Number(123)
//123
console.log(num.valueOf())
var date = new Date()
//1526990889729
console.log(date.valueOf())
var bool = new Boolean('123')
//true
console.log(bool.valueOf())
var obj = new Object({valueOf:()=>{
    return 1
}})
//依赖于内部实现
console.log(obj.valueOf())

运算隐式转换

前面提了那么多抽象概念,就是为了这里来理解具体转换的。  
对于+运算来说,规则如下:

  • +号左右分别进行取值,进行ToPrimitive()操作

  • 分别获取左右转换之后的值,如果存在String,则对其进行ToString处理后进行拼接操作。

  • 其他的都进行ToNumber处理

  • 在转换时ToPrimitive,除去Date为string外都按照ToPrimitive type为Number进行处理

说的自己都迷糊了快,一起结合代码来看一下

1+'2'+false
  1. 左边取原始值,依旧是Number

  2. 中间为String,则都进行toString操作

  3. 左边转换按照toString的规则,返回'1'

  4. 得到结果temp值'12'

  5. 右边布尔值和temp同样进行1步骤

  6. temp为string,则布尔值也转为string'false'

  7. 拼接两者 得到最后结果 '12false'

我们看一个复杂的

var obj1 = {
    valueOf:function(){
        return 1
    }
}
var obj2 = {
    toString:function(){
        return 'a'
    }
}
//2
console.log(1+obj1)
//1a
console.log('1'+ obj2)
//1a
console.log(obj1+obj2)

不管多复杂,按照上面的顺序来吧。

  • 1+obj1

  1. 左边就不说了,number

  2. 右边obj转为基础类型,按照type为number进行

  3. 先调用valueOf() 得到结果为1

  4. 两遍都是number,则进行相加得到2

  • 1+obj2

    1. 左边为number

    2. 右边同样按照按照type为number进行转化

    3. 调用obj2.valueOf()得到的不是原始值

    4. 调用toString() return 'a'

    5. 依据第二条规则,存在string,则都转换为string进行拼接

    6. 得到结果1a

  • obj1+obj2

    1. 两边都是引用,进行转换 ToPrimitive 默认type为number

    2. obj1.valueOf()为1 直接返回

    3. obj2.valueOf()得到的不是原始值

    4. 调用toString() return 'a'

    5. 依据第二条规则,存在string,则都转换为string进行拼接

    6. 得到结果1a

    到这里相信大家对+这种运算的类型转换了解的差不多了。下面就看一下另一种隐式类型转换

    == 抽象相等比较

    这种比较分为两大类,

    • 类型相同

    • 类型不同

    相同的就不说了,隐式转换发生在不同类型之间。规律比较复杂,规范比较长,这里也不列举了,大家可以查看抽象相等算法。简单总结一句,相等比较就不想+运算那样string优先了,是以number优先级为最高。概括而言就是,都尽量转成number来进行处理,这样也可以理解,毕竟比较还是期望比较数值。那么规则大概如下:  
    对于x == y

    1. 如果x,y均为number,直接比较

       没什么可解释的了
       1 == 2 //false
    2. 如果存在对象,ToPrimitive() type为number进行转换,再进行后面比较

      var obj1 = {
          valueOf:function(){
              return '1'
          }
      }
      1 == obj2  //true
      //obj1转为原始值,调用obj1.valueOf()
      //返回原始值'1'
      //'1'toNumber得到 1 然后比较 1 == 1
      [] == ![] //true
      //[]作为对象ToPrimitive得到 ''  
      //![]作为boolean转换得到0 
      //'' == 0 
      //转换为 0==0 //true
    3. 存在boolean,按照ToNumber将boolean转换为1或者0,再进行后面比较

      //boolean 先转成number,按照上面的规则得到1  
      //3 == 1 false
      //0 == 0 true
      3 == true // false
      '0' == false //true
    4. 如果x为string,y为number,x转成number进行比较

      //'0' toNumber()得到 0  
      //0 == 0 true
      '0' == 0 //true

    相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

    推荐阅读:

    前端中排序算法实例详解

    JS中使用接口步骤详解

    以上是js隱式類型轉換使用步驟詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

    陳述
    本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
    JavaScript和Web:核心功能和用例JavaScript和Web:核心功能和用例Apr 18, 2025 am 12:19 AM

    JavaScript在Web開發中的主要用途包括客戶端交互、表單驗證和異步通信。 1)通過DOM操作實現動態內容更新和用戶交互;2)在用戶提交數據前進行客戶端驗證,提高用戶體驗;3)通過AJAX技術實現與服務器的無刷新通信。

    了解JavaScript引擎:實施詳細信息了解JavaScript引擎:實施詳細信息Apr 17, 2025 am 12:05 AM

    理解JavaScript引擎內部工作原理對開發者重要,因為它能幫助編寫更高效的代碼並理解性能瓶頸和優化策略。 1)引擎的工作流程包括解析、編譯和執行三個階段;2)執行過程中,引擎會進行動態優化,如內聯緩存和隱藏類;3)最佳實踐包括避免全局變量、優化循環、使用const和let,以及避免過度使用閉包。

    Python vs. JavaScript:學習曲線和易用性Python vs. JavaScript:學習曲線和易用性Apr 16, 2025 am 12:12 AM

    Python更適合初學者,學習曲線平緩,語法簡潔;JavaScript適合前端開發,學習曲線較陡,語法靈活。 1.Python語法直觀,適用於數據科學和後端開發。 2.JavaScript靈活,廣泛用於前端和服務器端編程。

    Python vs. JavaScript:社區,圖書館和資源Python vs. JavaScript:社區,圖書館和資源Apr 15, 2025 am 12:16 AM

    Python和JavaScript在社區、庫和資源方面的對比各有優劣。 1)Python社區友好,適合初學者,但前端開發資源不如JavaScript豐富。 2)Python在數據科學和機器學習庫方面強大,JavaScript則在前端開發庫和框架上更勝一籌。 3)兩者的學習資源都豐富,但Python適合從官方文檔開始,JavaScript則以MDNWebDocs為佳。選擇應基於項目需求和個人興趣。

    從C/C到JavaScript:所有工作方式從C/C到JavaScript:所有工作方式Apr 14, 2025 am 12:05 AM

    從C/C 轉向JavaScript需要適應動態類型、垃圾回收和異步編程等特點。 1)C/C 是靜態類型語言,需手動管理內存,而JavaScript是動態類型,垃圾回收自動處理。 2)C/C 需編譯成機器碼,JavaScript則為解釋型語言。 3)JavaScript引入閉包、原型鍊和Promise等概念,增強了靈活性和異步編程能力。

    JavaScript引擎:比較實施JavaScript引擎:比較實施Apr 13, 2025 am 12:05 AM

    不同JavaScript引擎在解析和執行JavaScript代碼時,效果會有所不同,因為每個引擎的實現原理和優化策略各有差異。 1.詞法分析:將源碼轉換為詞法單元。 2.語法分析:生成抽象語法樹。 3.優化和編譯:通過JIT編譯器生成機器碼。 4.執行:運行機器碼。 V8引擎通過即時編譯和隱藏類優化,SpiderMonkey使用類型推斷系統,導致在相同代碼上的性能表現不同。

    超越瀏覽器:現實世界中的JavaScript超越瀏覽器:現實世界中的JavaScriptApr 12, 2025 am 12:06 AM

    JavaScript在現實世界中的應用包括服務器端編程、移動應用開發和物聯網控制:1.通過Node.js實現服務器端編程,適用於高並發請求處理。 2.通過ReactNative進行移動應用開發,支持跨平台部署。 3.通過Johnny-Five庫用於物聯網設備控制,適用於硬件交互。

    使用Next.js(後端集成)構建多租戶SaaS應用程序使用Next.js(後端集成)構建多租戶SaaS應用程序Apr 11, 2025 am 08:23 AM

    我使用您的日常技術工具構建了功能性的多租戶SaaS應用程序(一個Edtech應用程序),您可以做同樣的事情。 首先,什麼是多租戶SaaS應用程序? 多租戶SaaS應用程序可讓您從唱歌中為多個客戶提供服務

    See all articles

    熱AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智慧驅動的應用程序,用於創建逼真的裸體照片

    AI Clothes Remover

    AI Clothes Remover

    用於從照片中去除衣服的線上人工智慧工具。

    Undress AI Tool

    Undress AI Tool

    免費脫衣圖片

    Clothoff.io

    Clothoff.io

    AI脫衣器

    AI Hentai Generator

    AI Hentai Generator

    免費產生 AI 無盡。

    熱門文章

    R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
    1 個月前By尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O.最佳圖形設置
    1 個月前By尊渡假赌尊渡假赌尊渡假赌
    威爾R.E.P.O.有交叉遊戲嗎?
    1 個月前By尊渡假赌尊渡假赌尊渡假赌

    熱工具

    DVWA

    DVWA

    Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

    PhpStorm Mac 版本

    PhpStorm Mac 版本

    最新(2018.2.1 )專業的PHP整合開發工具

    SublimeText3 英文版

    SublimeText3 英文版

    推薦:為Win版本,支援程式碼提示!

    SecLists

    SecLists

    SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

    ZendStudio 13.5.1 Mac

    ZendStudio 13.5.1 Mac

    強大的PHP整合開發環境