js對象類型

js中有六種數(shù)據(jù)類型姥卢,包括五種基本數(shù)據(jù)類型(Number,String,Boolean,Null,Undefined),和一種混合數(shù)據(jù)類型(Object)。下面就跟著小編一起來看下吧

js中有六種數(shù)據(jù)類型赂苗,包括五種基本數(shù)據(jù)類型(Number,String,Boolean,Null,Undefined),和一種混合數(shù)據(jù)類型(Object)。

前面說到js中變量是松散類型的贮尉,因此有時候我們需要檢測變量的數(shù)據(jù)類型哑梳。

typeof操作符可以檢測變量的數(shù)據(jù)類型(輸出的是一個關于數(shù)據(jù)類型的字符串)。

返回如下6種字符串:number,string,boolean,object,undefined,function.且看如下例子:

var x = 1;

console.log(typeof x);//number

var a = undefined;

console.log(typeof a);//undefined

var b = null;

console.log(typeof b);//object绘盟,(null是空對象引用/或者說指針)。

var c = new Object();

console.log(typeof c);//object

var e = [1,2,3];

console.log(typeof e);//object

var d = function(){

// ... 語句塊

}

console.log(typeof d);//function


1.Number類型

Number類型包含整數(shù)和浮點數(shù)(浮點數(shù)數(shù)值必須包含一個小數(shù)點悯仙,且小數(shù)點后面至少有一位數(shù)字)兩種值龄毡。

浮點數(shù)將會自動轉換為整數(shù)。

var num = 1.00;

console.log(num);//1锡垄,自動轉換為整數(shù)

浮點數(shù)的最高精度是17位沦零,看下面的例子,結果竟然不是0.3货岭,至于其他編程語言路操,也會遇到這種情況(關于浮點數(shù)計算會產(chǎn)生舍入誤差問題疾渴,其他有些編程語言也會出現(xiàn)類似情況。)

var num1 = 0.1;

var num2 = 0.2;

console.log(num1 + num2);//0.30000000000000004

NaN:非數(shù)字類型屯仗。特點:① 涉及到的 任何關于NaN的操作搞坝,都會返回NaN?? ② NaN不等于自身。

var ab = "a1";

console.log(ab/10);// NaN

console.log(NaN == NaN);// false;

isNaN()函數(shù)魁袜,用于判斷是否是一個非數(shù)字類型桩撮。如果傳入的參數(shù)是一個非數(shù)字類型,那么返回true峰弹;否則返回false;

isNaN()函數(shù)店量,傳入一個參數(shù),函數(shù)會先將參數(shù)轉換為數(shù)值鞠呈。

如果參數(shù)類型為對象類型融师,會先調(diào)用對象的valueOf()方法, 再確定該方法返回的值是否可以轉換為數(shù)值類型蚁吝。如果不能旱爆,再調(diào)用對象的toString()方法,再確定返回值灭将。

數(shù)值轉換:

Number()轉型函數(shù)疼鸟,可以用于任何數(shù)據(jù)類型;

parseInt()庙曙,將值轉換為整型空镜,用的比較多;

parseFloat()捌朴;將值轉換為浮點型吴攒。

2.String類型

字符串類型中的單引號與雙引號的作用效果完全一樣。

字符串有l(wèi)ength屬性砂蔽⊥菡可以取得字符串的長度。var str = “hello”;console.log(str.length);//5

字符串的值是不可變的左驾。要改變一個字符串的值镣隶,首先要銷毀原來的字符串,再用另一個包含新值的字符串去填充該字符串诡右。

var lang = “java”;

lang += “script”;

上面這段代碼安岂,先創(chuàng)建一個能容納10個字符的字符串,然后在這個字符串中填充java和script字符串帆吻,最后銷毀原來的字符串java和scrip字符串域那,因為這兩個字符串此時已經(jīng)沒用了。這個個過程是在后臺發(fā)生的猜煮。

字符串轉換:轉型函數(shù)String(),適用于任何數(shù)據(jù)類型(null,undefined 轉換后為null和undefined)次员;toString()方法(null,defined沒有toString()方法)败许。

var bc = "lijinwen";

var bd = null;

var be = undefined;

console.log(bc.toString());

//console.log(bd.toString());//error 報錯

//console.log(be.toString());//error 報錯

console.log("------");

console.log(String(bc));

console.log(String(bd));

console.log(String(be));

3.Boolean類型

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

轉換為boolean值: 轉型函數(shù)Boolean(),將某個值轉換為Boolean類型淑蔚。詳細內(nèi)容市殷,后面會慢慢的補充。

4.Null類型

null類型被看做空對象指針束倍,前文說到null類型也是空的對象引用被丧。只有一個值,即null值绪妹,所以甥桂,在你 用typeof 操作符去檢測null類型的值時,結果是object類型邮旷。

如果你定義了一個變量黄选,但是想在以后把這個變量當做一個對象來用,那么最好將該對象初始化為null值婶肩。

5.Undefined類型

只有一個值办陷,即undefined值。使用var聲明了變量律歼,但未給變量初始化值民镜,那么這個變量的值就是undefined。

var name = "lijinwen";

var age;

console.log(name);//lijinwen

console.log(age);//undefined

//console.log(height);//error险毁,變量height沒有聲明

console.log(typeof name);//string

console.log(typeof age);//undefined

console.log(typeof height);//undefined制圈,變量height沒有聲明

上面這段代碼中,age雖然聲明了畔况,但是沒有初始化值鲸鹦,所以,打印出來的是undefined.而變量height沒有聲明跷跪,故報錯馋嗜。

但是用typeof操作符去檢測數(shù)據(jù)類型的時候,變量age沒有初始化吵瞻,結果是undefined葛菇,沒有聲明變量的height檢測的類型也是undefined.

6.Object類型

js中對象是一組屬性與方法的集合。具體的關于對象的創(chuàng)建方式以及對象的各種特性橡羞,會在后面的引用類型的章節(jié)中? 做詳細介紹熟呛。這里就簡單介紹一下六大數(shù)據(jù)類型中的Object.

①constructor屬性:構造函數(shù)屬性,可確定當前對象的構造函數(shù)。

var o = new Object();

console.log(o.constructor == Object);//true

var arr = new Array();

console.log(arr.constructor == Array);//true

②hasOwnProperty(propertyName):判斷屬性是否存在于當前對象實例中(而不是原型對象中)尉姨。這個在后面的面向?qū)ο蟮恼鹿?jié)中? 有詳細的講解。

③…更多關于Object請查看后面的章節(jié)面向?qū)ο蟆?/p>


參考:http://www.jb51.net/article/101341.htm

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末吗冤,一起剝皮案震驚了整個濱河市又厉,隨后出現(xiàn)的幾起案子九府,更是在濱河造成了極大的恐慌,老刑警劉巖覆致,帶你破解...
    沈念sama閱讀 218,386評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件侄旬,死亡現(xiàn)場離奇詭異,居然都是意外死亡煌妈,警方通過查閱死者的電腦和手機儡羔,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評論 3 394
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來璧诵,“玉大人汰蜘,你說我怎么就攤上這事≈蓿” “怎么了族操?”我有些...
    開封第一講書人閱讀 164,704評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長比被。 經(jīng)常有香客問我色难,道長,這世上最難降的妖魔是什么等缀? 我笑而不...
    開封第一講書人閱讀 58,702評論 1 294
  • 正文 為了忘掉前任枷莉,我火速辦了婚禮,結果婚禮上尺迂,老公的妹妹穿的比我還像新娘笤妙。我一直安慰自己,他們只是感情好枪狂,可當我...
    茶點故事閱讀 67,716評論 6 392
  • 文/花漫 我一把揭開白布危喉。 她就那樣靜靜地躺著,像睡著了一般州疾。 火紅的嫁衣襯著肌膚如雪辜限。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,573評論 1 305
  • 那天严蓖,我揣著相機與錄音薄嫡,去河邊找鬼。 笑死颗胡,一個胖子當著我的面吹牛毫深,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播毒姨,決...
    沈念sama閱讀 40,314評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼哑蔫,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起闸迷,我...
    開封第一講書人閱讀 39,230評論 0 276
  • 序言:老撾萬榮一對情侶失蹤嵌纲,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后腥沽,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體逮走,經(jīng)...
    沈念sama閱讀 45,680評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,873評論 3 336
  • 正文 我和宋清朗相戀三年今阳,在試婚紗的時候發(fā)現(xiàn)自己被綠了师溅。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,991評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡盾舌,死狀恐怖墓臭,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情矿筝,我是刑警寧澤起便,帶...
    沈念sama閱讀 35,706評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站窖维,受9級特大地震影響榆综,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜铸史,卻給世界環(huán)境...
    茶點故事閱讀 41,329評論 3 330
  • 文/蒙蒙 一鼻疮、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧琳轿,春花似錦判沟、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至琉闪,卻和暖如春迹炼,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背颠毙。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評論 1 270
  • 我被黑心中介騙來泰國打工斯入, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人蛀蜜。 一個月前我還...
    沈念sama閱讀 48,158評論 3 370
  • 正文 我出身青樓刻两,卻偏偏與公主長得像,于是被迫代替她去往敵國和親滴某。 傳聞我的和親對象是個殘疾皇子磅摹,可洞房花燭夜當晚...
    茶點故事閱讀 44,941評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 文章配套視頻 https://study.163.com/course/introduction/10059730...
    撩課_葉建華閱讀 4,946評論 7 25
  • 變量 聲明變量 命名變量區(qū)分大小寫的語言第一個字符是字母或下劃線_,數(shù)字不能作為第一個字符字符必須是字母滋迈,數(shù)字或者...
    flyingtoparis閱讀 812評論 0 0
  • 語句 JavaScript程序的執(zhí)行單位為行(line),也就是一行一行地執(zhí)行偏瓤。一般情況下杀怠,每一行就是一個語句。 ...
    米塔塔閱讀 458評論 1 10
  • 前端07班 王語句JavaScript程序的執(zhí)行單位為行(line)厅克,也就是一行一行地執(zhí)行。一般情況下橙依,每一行就是...
    ea203453e188閱讀 887評論 0 4
  • 4.1消費者偏好與效用 4.1消費者選擇理論是用來解釋如下問題的:需求規(guī)律和消費者如何通過消費獲得最大效用证舟; 4....
    小丫屠閱讀 3,077評論 2 1