摘要:是的一種實現方式,輕量級的腳本語言,本身不提供輸入輸出相關的,提供。如果同一個函數被多次聲明后面的聲明就會覆蓋前面的聲明聲明函數的方法函數表達式構造函數數組是方括號里面按次序排列的一組值。
JavaScript
JavaScript是ECMAScript的一種實現方式,輕量級的腳本語言,本身不提供I/O(輸入/輸出)相關的API,host提供。
語法
變量: 變量是對"值"的具名引用,變量名區分大小寫. 聲明變量的六種方法:var function let const import class
變量提升:JavaScript引擎的工作方式,先解析代碼,獲取所有被聲明的變量,然后再一行行地運行.所有的變量聲明語句會被放在代碼的頭部. let聲明變量:不存在變量提升(先聲明后使用),存在塊級作用域.存在"暫時性死區"(在let/const未聲明前,使用則報錯.),暫時性死區的本質是執行當當前作用域,在等到變量聲明那一行出現,在獲取和使用該變量.不允許重復聲明. const聲明常量,聲明之后不可改變,存在塊級作用域,存在"暫時性死區",保證了內存地址存在的數據不可改變,指針永遠執行它.
標識符: 變量名,函數名等.命名規則,首字母可以是字母或$或_,余下字符:除了Unicode字母,美元符號和下劃線,還可以用數字0-9 使用駝峰命名法.
保留字:不能作為標識符使用
agargument,break,case,catch,class,const,continue,debugger, default,delete,do,else,enum,eval,export,extends,flase,finally,for,function,if,implements, import,in,instanceof,interface,let,new,null,package,private, protected,public,return,static,super,switch,this,throw,true,try,typeof,var,void,while,with,yield.
注釋: 一種單行注釋:用//開頭. 多行注釋: /和/之間.
語句: if結構 if..else結構 switch結構 三元運算符?: while循環 for循環 do...while循環 break語句和continue語句 lable標簽if語句,if-else語句,switch語句,注意switch語句后面的表達式,與case語句后面的表達式比較運算結果時,采用的是嚴格相等運算符(===),而不是相等運算符(==),即不會發生類型轉換.
數據類型七種: number (數字),string(字符串),boolean(布爾型),undefined(未定義),null(空),object(對象), Symbol(復合).
原始類型:Number/String/Boolean ,特殊值:null/undefined. 合成類型:object,存放許多值的容器.對象細分為:狹義的對象,數組,函數. 判斷一個值的類型: typeof運算符, instanceof運算符 object.prototype.toString運算符 歷史遺留,typeof null 會返回object instanceof可以區分array和object
null和undefined: null是一個表示"空"的對象,轉為數值時為0,undefined是一個表示"此處無定義"的原始值,轉為數值為NaN.
null:好比待補球員. undefined: 當變量聲明了,但沒有賦值,調用函數時,該提供的參數沒有提供,該參數等于undefined.對象沒有賦值的屬性,函數沒有返回值時,默認返回undefined.
Bollean:真true,假false.以下運算符返回布爾值,前置邏輯運算符! ,相等運算符 === !== == != 比較運算符 > >= < <=
以下六個值被轉為false(undefined,null,false,0 NaN, ""或"),其他值都視為true,空數組{}和空對象對應的布爾值都是true.
number: 在JavaScript內部,所有的數字都是小數(64位浮點數),對于某些運算需要整數,會自動把64位數浮點數轉換為32位整數,再進行運算. Js中最大數值為2的1024次方,超出則Infinity. Js中最小值為2的-1075次方,超出則0.
數值的進制:十進制,十六進制(0x或0X),八進制(0o或0O),二進制(0B或0b).歷史遺留,0888會被看做八進制.
特殊數值:正零和負零,Js內部的2個0,一個是+0,-0,區別是64位浮點數表示法的符號位不同,它們為等價的。 NaN是JavaScript的特殊值,數據類型依然屬于Number,表示“非數字”,主要出現在將字符串解析成數字出錯的場合。NaN不等于任何值,包括它本身。 Infinity.表示“無窮”。
string:字符串"abc"或"abc", 要在""里面使用單引號加反斜杠,用來轉義。 length屬性返回字符串長度。
object:object是JavaScript語言的核心概念,對象是一組"鍵值對(key-value)"的集合,屬性的讀取與賦值(.運算符和[]運算符)
查看一個對象本身的所有屬性,可以使用object.keys方法. 屬性的刪除,只能刪除對象本身的屬性 delete Objectname.value;
屬性是否存在 in運算符 "value" in Objectname; 屬性的遍歷 for..in循環,用來遍歷一個對象的全部屬性,不僅遍歷對象自身的屬性,還遍歷繼承的屬性。
function:函數是一段可以反復調用的代碼塊,是處理數據的方法,是JavaScript的第一等公民。函數還能接受輸入的參數,不同參數返回不同值。
如果同一個函數被多次聲明,后面的聲明就會覆蓋前面的聲明.
聲明函數的方法:function 函數表達式 Function構造函數
array: 數組是方括號里面按次序排列的一組值。可以先定義后賦值,可以放入任何數據類型。
(1)function命令 function print(s) { //function命令后面就是函數名,函數名后面一組圓括號,里面是傳入的參數,函數體放入大括號里面。 console.log(s); } (2)函數表達式 let print = function(s) { //表達式的function命令之后,如要加函數名,則只會在函數體內部有效,在函數體外部無效. console.log(s); }; (3)Function構造函數 let add = new Function ( "x", "y", "return x + y" );運算符
處理數據的基本方法,從現有的值得到新的值.
算術運算符,比較運算符,布爾運算符,二進制運算符,其他運算符,運算順序.
算術運算符:加法運算符(+),減法運算符(-),乘法運算符(),除法運算符(/),指數運算符(*)余數運算符(%),自增運算符(++x/++x),
自減運算符(--x/x--),數值運算符(+),負數值運算符(-x) 加法運算符允許非數值的相加.
比較運算符: >(大于運算符) <(小于運算符) <=(小于或等于運算符) >=(大于或等于運算符) ==(相等運算符) ==(嚴格運算符) !=(不相等運算符)
!==(嚴格不相等運算符)
布爾運算符:!(取反運算符) &&(且運算符) ||(或運算符) ?:(三元運算符) ·以下運算符(undefined,null,false,0,NaN,"")取反為true.
二進制位運算符:
其他運算符,運算順序:
void運算符,執行一個表達式,如何不返回任何值.或者返貨undefined.
逗號運算符,用于對兩個表達式求職,并返回后一個表達式的值.
運算符的優先級別:
()最高
一元運算符 ++ -- !.
算術運算符: 先* / % 后 + -
關系運算符 > >= < <=
相等運算符 == != === !==
邏輯運算符 先$$ 后||
專題一:數據類型的轉換Number(),解析為數值,不可解析與undefined則NaN,空字符串與null則為0,true轉為1.false轉為0.
String(),解析為字符串。
Boolean(),轉為布爾值,以下五個值(undefined,null,-0或+0,NaN,""(空字符串))的轉換結果為false,其他的值為true.
在JavaScript中,所有數據保存在堆(heap)里面,執行上下文的的執行順序借用棧數據結構的存取方式.棧是先進先出(FIFO),而JavaScript具有垃圾回收機制,通過標記清除算法清除不再使用的對象.
一個頁面開始加載JS就進入全局環境,每段函數的加載,進入函數環境(又稱為執行上下文).執行上下文分為兩個階段:創建階段:(創建變量對象,建立作用域鏈,確定this指向)+代碼執行階段(變量賦值,函數引用,執行額外代碼)
原型:所有對象都有它.
構造函數:可以通過new創建一個對象.
實例:通過構造函數和new創建的對象就是實例,實例通過_proto_指向原型,通過constructor指向構造函數.
原型鏈: _proto_將對象連接成原型鏈,實現繼承與共享屬性的對象鏈.
//實例 const instance = new Object() //實例為instance 構造函數是Object參考
(1)網道-互聯網開發文檔(https://wangdoc.com/).
(2)ECMAScript 6 入門 (http://es6.ruanyifeng.com/).
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/101763.html
摘要:深入之繼承的多種方式和優缺點深入系列第十五篇,講解各種繼承方式和優缺點。對于解釋型語言例如來說,通過詞法分析語法分析語法樹,就可以開始解釋執行了。 JavaScript深入之繼承的多種方式和優缺點 JavaScript深入系列第十五篇,講解JavaScript各種繼承方式和優缺點。 寫在前面 本文講解JavaScript各種繼承方式和優缺點。 但是注意: 這篇文章更像是筆記,哎,再讓我...
摘要:忍者級別的函數操作對于什么是匿名函數,這里就不做過多介紹了。我們需要知道的是,對于而言,匿名函數是一個很重要且具有邏輯性的特性。通常,匿名函數的使用情況是創建一個供以后使用的函數。 JS 中的遞歸 遞歸, 遞歸基礎, 斐波那契數列, 使用遞歸方式深拷貝, 自定義事件添加 這一次,徹底弄懂 JavaScript 執行機制 本文的目的就是要保證你徹底弄懂javascript的執行機制,如果...
摘要:個人前端文章整理從最開始萌生寫文章的想法,到著手開始寫,再到現在已經一年的時間了,由于工作比較忙,更新緩慢,后面還是會繼更新,現將已經寫好的文章整理一個目錄,方便更多的小伙伴去學習。 showImg(https://segmentfault.com/img/remote/1460000017490740?w=1920&h=1080); 個人前端文章整理 從最開始萌生寫文章的想法,到著手...
閱讀 3495·2023-04-26 02:44
閱讀 1632·2021-11-25 09:43
閱讀 1523·2021-11-08 13:27
閱讀 1888·2021-09-09 09:33
閱讀 906·2019-08-30 15:53
閱讀 1768·2019-08-30 15:53
閱讀 2780·2019-08-30 15:53
閱讀 3114·2019-08-30 15:44