摘要:布爾類型的數(shù)據(jù)類型轉(zhuǎn)換在中,可以將所有的數(shù)據(jù)類型的值轉(zhuǎn)換為布爾類型的值。
語法 區(qū)分大小寫
`JavaScript`中的變量、函數(shù)名都是區(qū)分大小寫的,`name`,`Name`,`NAME`,不是同一個變量標識符
標識符就是變量、函數(shù)、屬性的名字或者函數(shù)的參數(shù)注釋
注釋就是不被計作程序語句,專門用來給程序員自己看的內(nèi)容 //單行注釋 /* * 多行注釋 * */變量
變量就是一個用來存儲數(shù)據(jù)的,聲明變量用`var`
//聲明一個變量,名字叫name var name;
如果要定義多個變量,有兩種方式可以定義:
//方式一:分開定義 var name; var age; var sex; //方式二:統(tǒng)一定義 var name,age,sex;給變量賦值
//變量可以在聲明的時候賦值 var name = "John"; //也可以聲明以后再賦值 var name; name = "John"; //這里的變量值也可以是"John",單引號和雙引號都表示字符串 //賦值以后可以修改變量的值 // 方法一 var name = "John"; name = "Tome"; console.log(name);//Tome //方法二 var name; name = "John"; name = "Tome"; console.log(name)//Tome變量的作用域
function demo(){ var name = "John"; } demo();//調(diào)用函數(shù)--在函數(shù)名后面加括號`()`表示執(zhí)行該函數(shù) console.log(name);//錯誤
在上面這段代碼中,在函數(shù)內(nèi)部定義了一個局部變量,局部變量在函數(shù)運行結(jié)束以后就會被銷毀,此時在函數(shù)外面調(diào)用name變量的時候,name這個變量并不存在
function demo(){ name = "John";//全局變量 } demo(); console.log(name); //John
上面這段代碼中在函數(shù)內(nèi)聲明了一個變量,但是并沒有用var聲明,此時當函數(shù)運行過后,name就是一個全局變量,那么函數(shù)運行結(jié)束以后,這個變量并沒有被銷毀,所以在函數(shù)體外部依然可以找到name這個變量
前文中提到的全局變量、局部變量、函數(shù)體等知識點雖然沒有學過,但是可以提前理解一下,后面會做詳細介紹數(shù)據(jù)類型
另外,雖然省略var操作符可以定義全局變量,但是不推薦這樣做,因為在局部中定義全局變量難以維護
在javaScript中有5種數(shù)據(jù)類型(基本數(shù)據(jù)類型):Undefined,Null,Boolean,Number,String。
Object也是一種數(shù)據(jù)類型,但是是復(fù)雜數(shù)據(jù)類型,Object本質(zhì)上是由一對健值對組成。
typeof用來檢測數(shù)據(jù)類型,返回的結(jié)果有:
"undefined"---未定義
"boolean"---布爾類型
"string"---字符串
"number"---數(shù)字類型
"object"---對象或者是null
function`---函數(shù)類型的數(shù)據(jù)
typeof null會返回object,這是因為特殊值null被認為是一個空對象
// undefined var name; console.log(typeof name); //var定義,結(jié)果是string,let定義是undefined // let,ECMAScript6中定義數(shù)據(jù)的關(guān)鍵字 // boolean var flag = true; console.log(typeof flag); //boolean // string var name = "Json"; console.log(typeof name); //string // object var obj = { "name": "Json", "age": 20 }; console.log(typeof obj); //object // function function add(a,b) { return a + b; } console.log(typeof add);//functionUndefined類型
Undefined只有一個值,即undefined。對于聲明了但是沒有初始化的變量,其值就是一個undefined。
var name; console.log(name == undefined);// true // 這個例子類似于 var name = undefined; console(name == undefined);// trueNull類型
Null類型是一個只有一個值的數(shù)據(jù)類型,這個值是null。
var person = null; console.log(typeof person);// object
這里給person賦值為null,表示person是一個空指針的變量,將來指向一個對象。
所以如果要定義一個變量,將來用于保存對象,那么賦初始值的時候要賦值為null。比如下面這個例子:
var person = null; if(person == null){ person = { "name":"Jerry", "age":20 } }Boolean類型
Boolean有兩個字面值:true和false。
var flag = true; var isSuccess = false;
布爾類型的數(shù)據(jù)類型轉(zhuǎn)換
在JavaScript中,可以將所有的數(shù)據(jù)類型的值轉(zhuǎn)換為布爾類型的值。轉(zhuǎn)換方法如下:
var name = "Json"; var nameBoolean = Boolean(name); console.log(nameBoolean);//true
轉(zhuǎn)換規(guī)則:
String類型,非空為true,空為false
Number類型,非0為true,0和NaN為false
Object類型,任何對象為true,null為false
比如我們可以用字符串的非空作為判斷的條件:
var message = "Please send me latter"; if(message){ send(message); } function send(mes){ console.log("發(fā)送消息---消息內(nèi)容為"+mes); }Number類型
關(guān)于Number類型的數(shù)據(jù),我們不去研究八進制、十六進制,這些類型的數(shù)據(jù)會給我們的學習帶來不小的負擔,另外數(shù)值的范圍我們也不去研究。
數(shù)值轉(zhuǎn)換關(guān)于數(shù)值轉(zhuǎn)換,需要學習三個函數(shù):Number(),parseInt(),parseFloat()。
Number():用于將任何數(shù)據(jù)類型轉(zhuǎn)換為數(shù)值類型的數(shù)據(jù);
parseInt():將字符串類型的數(shù)字轉(zhuǎn)換為int類型的數(shù)據(jù);
parseFloat:將字符串類型的數(shù)據(jù)轉(zhuǎn)換為float類型的數(shù)據(jù)。
Number():
如果是Boolean類型的數(shù)據(jù),true被轉(zhuǎn)換為1,false被轉(zhuǎn)換為0;
如果是數(shù)字,只是簡單的傳入和返回;
如果是null,返回0;
如果是undefined返回的是NaN
如果是字符串
如果是"123",返回123,如果是"0123"返回的是123;
如果是十六進制的數(shù)據(jù),則會返回對應(yīng)的十進制的值;
如果是空字符串,則返回0
var number1 = Number("John");//NaN var number2 = Number("");//0 var number3 = Number("090");//90 var number4 = Number(true);//1 var number5 = Number(false);//0 var number8 = 12+"number";//NaN
parseInt():
var number = parseInt("070");//56
前面的Number()則是將"070"轉(zhuǎn)換成了70,而parseInt()則是將070轉(zhuǎn)換成了56,這是因為parseInt()函數(shù)將"070"當作是八進制的一個數(shù)值進行轉(zhuǎn)換
為了消除這種困惑,在parseInt()函數(shù)中還有另一個參數(shù)作為補充,第二個參數(shù)可以指定被轉(zhuǎn)換值按照什么類型的值去轉(zhuǎn)換:
var num1 = parseInt("10", 2);//2 (按二進制解析) var num2 = parseInt("10", 8);//8 (按八進制解析) var num3 = parseInt("10", 10);//10(按十進制解析) var num4 = parseInt("10", 16);//16(按十六進制解析)
parseFloat()與parseInt()類似,是從第一個字符開始解析,解析到字符串末尾或者遇到第二個小數(shù)點為止,比如’12.34.32’解析的結(jié)果就是12.34。
下面的例子中,標記有(了解)的可以不做重點關(guān)注:
var num1 = parseFloat("1234blue");//1234 (整數(shù)) var num2 = parseFloat("0xA"); //0 (了解) var num3 = parseFloat("22.5");//22.5 var num4 = parseFloat("22.34.5");//22.34 var num5 = parseFloat("0908.5"); //908.5 var num6 = parseFloat("3.125e7"); //31250000 (了解)String類型
String類型的數(shù)據(jù),簡單來說,就是由雙引號("")和單引號("")包裹起來的都是String類型的數(shù)據(jù)。
在這里,單引號和雙引號都可以用來表示字符串,要注意一點,引號要對稱:
String name = "Jhon";//前后引號不一致,錯誤字符串的拼接
String name = "Tom"; String subString = "name:"+ name; // 如果是數(shù)字類型的數(shù)據(jù)和字符串拼接,那么會默認將數(shù)字轉(zhuǎn)換成字符串,然后拼接 String stringNumber = 1 + "string";字符串轉(zhuǎn)換
toString()方法
toString()默認是以十進制的方式去轉(zhuǎn)換的,但是我們可以通過添加參數(shù)來規(guī)定轉(zhuǎn)換的方式
var num = 10; console.log(num.toString());// "10"--十進制 console.log(num.toString(2));// "1010"---二進制 console.log(num.toString(8));// "12"---八進制 console.log(num.toString(10));// "10"---十進制 console.log(num.toString(16));// "a"---十六進制
String()方法
String()方法的轉(zhuǎn)換規(guī)則與toString()方法基本類似,這是因為它的轉(zhuǎn)換規(guī)則:
如果被轉(zhuǎn)換的值有toString()方法,就調(diào)用toString()方法;
如果被轉(zhuǎn)換值是null,返回null;
如果被轉(zhuǎn)換值是undefined,返回undefined。
var value1 = 30; var value2 = null; var value3 = undefined; console.log(String(value1));//"30" console.log(String(value2));//"null" console.log(String(value3));//"undefined"Object類型
Object類型的數(shù)據(jù)其實就是一對健值對,健值對就是一個屬性對應(yīng)一個值,對象的創(chuàng)建方式可以有兩種,一種是用關(guān)鍵字new創(chuàng)建,一種是用花括號創(chuàng)建:
第一種
var obj = new Object();//創(chuàng)建一個對象 // 給對象添加屬性和值 obj.name = "Tom"; obj.age = 20; // 取對象中的值 console.log(obj.name);// "Tom" console.log(obj.age);// 20
第二種
var obj = { "name": "Tom", "age": 20 } // 這里是兩種取值方式 console.log(obj.name); //"Tom" console.log(obj.age); //20 console.log(obj["name"]); //"Tom" console.log(obj["age"]); //20
下面的這些知識點可以作為了解,后面會細講
參考文獻:Object 的每個實例都具有下列屬性和方法:
constructor:保存著用于創(chuàng)建當前對象的函數(shù)。構(gòu)造函數(shù)(constructor) 就是 Object();
hasOwnProperty(propertyName):檢查給定的屬性在當前對象實例中(而不是在實例 的原型中)是否存在。其中,作為參數(shù)的屬性名(propertyName)必須以字符串形式指定(例 如:o.hasOwnProperty("name"));
isPrototypeOf(object):用于檢查傳入的對象是否是傳入對象的原型;
propertyIsEnumerable(propertyName):用于檢查給定的屬性是否能夠使用 for-in 語句來枚舉。與 hasOwnProperty()方法一樣,作為參數(shù)的屬性名必須以字符串形式指定;
toLocaleString():返回對象的字符串表示,該字符串與執(zhí)行環(huán)境的地區(qū)對應(yīng);
toString():返回對象的字符串表示;
valueOf():返回對象的字符串、數(shù)值或布爾值表示。通常與 toString()方法的返回值相同。
《JavaScript高級程序設(shè)計》
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/106897.html
摘要:年,以為藍本的建議被提交給了歐洲計算機制造商協(xié)會,。而且給未經(jīng)聲明的變量賦值在嚴格模式下會導致拋出的錯誤。這也正是使用操作符檢測值時會返回的原因。函數(shù)檢查過程是。但是這個轉(zhuǎn)換過程會導致特殊的和值應(yīng)用位操作時,這兩個值會被當成來處理。 前言 本文是 Awesome JavaScript 系列文章的第一篇,本系列文章主要為 JavaScript 的一些常見知識點,是我在 JavaScrip...
摘要:年,以為藍本的建議被提交給了歐洲計算機制造商協(xié)會,。而且給未經(jīng)聲明的變量賦值在嚴格模式下會導致拋出的錯誤。這也正是使用操作符檢測值時會返回的原因。函數(shù)檢查過程是。但是這個轉(zhuǎn)換過程會導致特殊的和值應(yīng)用位操作時,這兩個值會被當成來處理。 前言 本文是 Awesome JavaScript 系列文章的第一篇,本系列文章主要為 JavaScript 的一些常見知識點,是我在 JavaScrip...
摘要:年,以為藍本的建議被提交給了歐洲計算機制造商協(xié)會,。而且給未經(jīng)聲明的變量賦值在嚴格模式下會導致拋出的錯誤。這也正是使用操作符檢測值時會返回的原因。函數(shù)檢查過程是。但是這個轉(zhuǎn)換過程會導致特殊的和值應(yīng)用位操作時,這兩個值會被當成來處理。 前言 本文是 Awesome JavaScript 系列文章的第一篇,本系列文章主要為 JavaScript 的一些常見知識點,是我在 JavaScrip...
摘要:作用域鏈的作用就是做標示符解析。事件循環(huán)還有個明顯的特點單線程。早期都是用作開發(fā),單線程可以比較好當規(guī)避同步問題,降低了開發(fā)門檻。單線程需要解決的是效率問題,里的解決思想是異步非阻塞。 0、前言 本人在大學時非常癡迷java,認為java就是世界上最好的語言,偶爾在項目中會用到一些javascript,但基本沒放在眼里。較全面的接觸javascript是在實習的時候,通過這次的了解發(fā)現(xiàn)...
閱讀 2310·2021-11-25 09:43
閱讀 2946·2019-08-30 15:52
閱讀 1897·2019-08-30 15:44
閱讀 985·2019-08-30 10:58
閱讀 764·2019-08-29 18:43
閱讀 3220·2019-08-29 18:36
閱讀 2321·2019-08-29 17:02
閱讀 1461·2019-08-29 17:01