數據類型及類型轉換

来源:https://www.cnblogs.com/wx-1998/archive/2019/09/17/11532529.html
-Advertisement-
Play Games

數據類型及類型轉換 JS的六大數據類型 JS有六種數據類型 1.基本數據類型: Number 123 String ‘abc’ Boolean true,false Undefined undefined Null 空 2.複雜數據類型 Object { } 三大引用類型 Object { } Ar ...


數據類型及類型轉換

JS的六大數據類型

  JS有六種數據類型 

    1.基本數據類型:

      Number      123

      String     ‘abc’

      Boolean     true,false

      Undefined    undefined

      Null      空

    2.複雜數據類型

      Object     {  }

     三大引用類型

      Object     {  }

      Array      [ " " ]

      Function    

 

 1.Number類型

  Number類型包含整數和浮點數(浮點數數值必須包含一個小數點,且小數點後面至少有一位數字)兩種值。

  NaN:非數字類型。特點:① 涉及到的任何關於NaN的操作,都會返回NaN   ② NaN不等於自身。

  isNaN() 函數用於檢查其參數是否是非數字值。

  isNaN(123)  //false

  isNaN("hello")  //true

 2.String類型

  字元串有length屬性。

  字元串轉換:轉型函數String(),適用於任何數據類型(null,undefined 轉換後為null和undefined;toString()法(null,defined沒有toString()方法)。

 3.Boolean類型

  該類型只有兩個值,true和false

 4.Undefined類型

  只有一個值,即undefined值。使用var聲明瞭變數,但未給變數初始化值,那麼這個變數的值就是undefined。

 5.Null類型

  null類型被看做空對象指針,前文說到null類型也是空的對象引用。

 6.Object類型

  js中對象是一組屬性與方法的集合。這裡就要說到引用類型了,引用類型是一種數據結構,用於將數據和功能組織在一起。引用類型有時候也被稱為對象定義,因為它們描述的是一類對象所具有的屬性和方法。

JS的類型轉換,強制轉換和隱式轉換

1.強制轉換

  通過String(),Number(),Boolean()函數強制轉換

1   var str=123;
2    var str1='123';
3    console.log(typeof str);              //number
4    console.log(typeof str1);              //string
5    console.log(typeof String(str));          //string
6    console.log(typeof Number(str1));             //number

2.隱式轉換

  JavaScript的數據類型分為六種,分別為null,undefined,boolean,string,number,object。object是引用類型,其它的五種是基本類型或者是原始類型。我們可以用typeof方法列印來某個是屬於哪個類型的。不同類型的變數比較要先轉類型,叫做類型轉換,類型轉換也叫隱式轉換。隱式轉換通常發生在運算符加減乘除,等於,還有小於,大於等。

1 console.log(typeof '10')    //string
2 console.log(typeof 11)         //number
3 console.log('11' < 4 )         //false              

   1.字元串加數字,數字就會轉成字元串。

   2.數字減字元串,字元串轉成數字。如果字元串不是純數字就會轉成NaN。字元串減數字也一樣。兩個字元串相減也先轉成數字。

   3.乘,除,大於,小於跟減的轉換也是一樣。

 1 console.log(10+'20')   //2010
 2 
 3 console.log(10-'20')    //-10 number
 4 console.log(10-'one')    //NaN not a number
 5 console.log(10-'101a')   //NaN
 6 console.log(10*'20')     //200 number
 7 console.log('10'*'20')   //200 number
 8 console.log(20/'10')     //2 number
 9 console.log('20'/'10')   //2 number
10 console.log('20'/'one')   //NaN

關於==

   1.undefined等於null

   2.字元串和數字比較時,字元串轉數字

   3.數字為布爾比較時,布爾轉數字

   4.字元串和布爾比較時,兩者轉數字

console.log(undefined==null)    //true
console.log('0'==0)         //true 字元串轉數字
console.log(0==false)       //true 布爾轉數字
console.log('0'==false)      //2個都轉成數字
console.log(null==false)     //false
console.log(undefined==false)  //false

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 10、流程式控制制語句 註:var obj = {};這裡的obj轉換boolean語句為true if語句和java是一樣的,判斷條件也是根據上篇博客提到的假性值 // 彈出一個帶輸入框的視窗 var value = prompt("請輸入。。。"); //輸入1 if(value=="1"){ al ...
  • 防抖和節流 在處理高頻事件,類似於window的resize或者scorll,或者input輸入校驗等操作時。如果直接執行事件處理器,會增大瀏覽器的負擔,嚴重的直接卡死,用戶體驗非常不好。 面對這種情況,我們一般可以採用防抖和節流的方式減少調用頻率。同時也不會影響實際效果。 一、防抖 防抖的作用是: ...
  • 下雪效果,轉自網路,快去試試吧 :) 原理 通過多張雪花圖片,不同速度的移動,達到下雪的效果。 清晰度: 清晰 模糊 遠近: 近 遠 HTML CSS ...
  • [TOC] js ( Javascript ) — 腳本語言 1. js的介紹 Javascript是一種運行在瀏覽器中的解釋型的編程語言。 Javascript 可以在網頁上實現複雜的功能,網頁展示不再是單純的簡單的靜態信息,而是實施的內容更新,互動式的地圖,2D/3D的動畫,滾動播放的音視頻等等 ...
  • 定義萬維網的核心語言、標準通用標記語言下的一個應用超文本標記語言(HTML)的第五次重大修改為什麼要有語義化標簽方便開發者閱讀,寫出更優雅的代碼,讓瀏覽器很好的解析,從而更好的解析網頁內容,更好的搜索引擎優化H5 新增標簽 定義萬維網的核心語言、標準通用標記語言下的一個應用超文本標記語言(HTML) ...
  • 摘要: 當年12306竟然要自己安裝證書... 原文: "知道所有道理,真的可以為所欲為" 公眾號:可樂 "Fundebug" 經授權轉載,版權歸原作者所有。 一、什麼是MITM 中間人攻擊(man in the middle attack, abbreviated to MITM),簡單的講,就是 ...
  • 第一步 安裝scss依賴,cnpm i node-sass sass-loader -D 註:sass-loader用來解析scss文件(-D 是 --save-dev 的簡寫) 第二步: 在build文件夾下的webpack.base.conf.js的rules裡面添加配置 { test: /\. ...
  • 發現了一個之前未留意的知識點,做個筆記。 當一個塊級元素的父元素開啟了flex佈局後,我們可以很輕鬆的將這個元素居中對齊,可以在父元素上加 justify-content: center; align-items: center;/*單行下的居中對齊*/ 或 justify-content: cen ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...