摘要:第二種接口的概念和面向對象編程相關接口視為一份合約,在合約里可以定義這份合約的類或接口的行為接口告訴類,它需要實現一個叫做的方法,并且該方法接收一個參數。
定場詩
八月中秋白露,路上行人凄涼;
小橋流水桂花香,日夜千思萬想。
心中不得寧靜,清早覽罷文章,
十年寒苦在書房,方顯才高志廣。
前言洛伊安妮·格羅納女士所著的《學習JavaScript數據結構與算法》第三版于2019年的5月份再次刊印發(fā)行,新版內容契合當下,實為JavaScript開發(fā)人員的必備之佳作。有幸重讀此版,與諸君分享共勉。
內容提要此章節(jié)為第2章-ECMAScript與TypeScript概述,主要介紹了JS和TS的相關概念,以及在JS新版本中的新特性:let、解構、箭頭函數等。
2.1 ECMAScript還是JavaScriptECMA是一個將信息標準化的組織。ECMAScript是一個語言的標準,而JavaScript是該標準(最流行)的一個實現。JS的版本問題或恰如:ECMAScript是JS身份證上的名字(標準),JavaScript是常用的稱呼(常見、親切)。
版本 | 簡稱 | 發(fā)布時間 | 備注 |
---|---|---|---|
ECMAScript5 | ES5 | 2009年12月 | |
ECMAScript2015 | ES6 | 2015年6月 | ECMAScript規(guī)范委員會決定每年更新標準一次,js的標準稱呼為:ECMAScript+年份 |
ECMAScript2016 | ES7 | 2016年6月 | ECMAScript第7個版本 |
ECMAScript2017 | ES8 | 2017年6月 | ECMAScript第8個版本 |
ES.NEXT | 泛指下一個版本的ECMAScript |
一定要明白,即便ES2015到ES2017已經發(fā)布,但不是所有的瀏覽器都支持新特性。
使用最新版的瀏覽器進行體驗
使用Babel.js對使用ECMAScript新語言特性的JavaScript代碼轉換成只使用廣泛支持的ES5特性的等價代碼
Babel.js是一個JavaScript的轉譯器,具體使用文檔:官網-傳送門 Babel.js中文網2.2 ES6+的新功能 let和const定義變量
不存在變量提升
console.log(a) // ReferenceError: Cannot access "a" before initialization let a = 10
不允許重復聲明定義變量
let a = 10 let a = 20 // SyntaxError: Identifier "a" has already been declared
變量作用域
> 塊狀作用域 {}
if (true) { const b = 10 } console.log(b) // ReferenceError: b is not definedlet和const到底選擇誰?
const與let的行為是一樣的,唯一的區(qū)別在于,使用const定義的變量是只讀的,也就是常量。
const保證的其實并不是變量的值不能改動,而是變量指向的內存地址所保存的數據不得改動。擴展:基本類型值和引用類型值
每一個變量都指向了一個內存地址。
基本類型值:指向了一個內存地址,變量的值就存儲在改內存內置中。
引用類型值:指向了一個內存地址,該內存地址中存儲的是一個指針,一個指向實際數據的指針。
const保證的是這個指針是固定的,總是指向另一個固定地址;但實際上指針指向的數據結構是否可變,則不能控制。模板字面量
模板字面量語法``提供了很大的幫助,支持JS書寫時換行,可定義多行字符串;使用${}插入變量的值。
let person = { name: "王二狗", age: 18 } let str = `給你介紹個人: 這個人的名字是${person.name} ` console.log(str)箭頭函數
箭頭函數 () => {} 簡化了函數語法
let f = () => { console.log("我是箭頭函數....") } f() // 簡化return關鍵字 let sum = (a, b) => a+b sum(1, 2)函數參數默認值
支持定義函數參數的默認值
function sum (x = 1, y = 2, z = 3) { return x + y + z }聲明展開與剩余參數
展開運算符... 將對象或數組展開為一層,亦可當做剩余參數
let p = { name: "人", age: 20, sex: "男" } let wangErGou = { ...p, name: "王二狗" } console.log(wangErGou) // 剩余參數 function sum (x, y, ...a) { return x * y * a.length } sum(1, 2, 2, "abc", true) // 6 等同于a是數組[2, "abc", true]解構
數組與對象解構
let [x, y] = [10, 20] console.log(x, y) // 10, 20 let {age, name} = { name: "李四", age: 20 } console.log(name, age) // 李四, 20
數組解構中許注意順序,對象解構中無需注意順序;解構中無對應的值,則改值為undefined
解構應用
交換變量值
let x = 10 let y = 20 [y, x] = [x, y]
屬性簡寫
let x = 10 let y = 10 let obj = {x, y} // 相當于 {x: x, y: y}簡寫方法名
對象中的方法名可簡寫
let obj = { name: "王二狗", print () { console.log(this.name) } }使用類進行面向對象編程
定義
class Book { constructor (title, author, isbn) { this.title = title this.author = author this.isbn = isbn } printIsbn () { console.log(this.isbn) } } let book = new Book("郭德綱相聲選", "郭德綱", "00111011") book.printIsbn()
繼承
class ITBook extends Book { constructor (title, author, isbn, technology) { // 代表調用父類構造函數 super(title, author, isbn) this.technology = technology } printTechnology () { console.log(this.technology) } } let jsBook = new ITBook("JS數據結構與算法", "Groner", "123456789", "JavaScript") jsBook.printIsbn() jsBook.printTechnology()乘方運算符
let r = 2 let area = Math.PI * r ** 2 console.log(area)模塊
CommonJS規(guī)范是服務器端模塊化開發(fā)規(guī)范,使用require方法加載;
AMD(Asynchronous Module Definition) 異步模塊定義,RequireJS是AMD最流行的實現,是瀏覽器端模塊化開發(fā)規(guī)范;
CMD(Common Module Definition) 通用模塊定義,SeaJS是CMD的流行實現,是瀏覽器端模塊化開發(fā)規(guī)范
ES6模塊化開發(fā)
export 導出模塊;import 導入模塊
// moduleA.js export const moduleA = "moduleA"
// html中引入,注意type="module"2.3 介紹TypeScript
TypeScript是一個開源的、漸進式包含類型的JavaScript超集,由微軟創(chuàng)建并維護。目的是讓開發(fā)者增強JavaScript的能力并使應用的規(guī)模擴展變得更容易。
TS在JavaScript中提供類型支持可以實現靜態(tài)檢查,從而更容易地重構代碼和尋找BUG。最后,TypeScript為被編譯為簡單的JavaScript代碼。
編寫時為.ts文件,使用TypeScript對其進行tsc編譯,最終為js文件
下載TypeScript
npm i -g typescript
創(chuàng)建.ts文件,寫入內容
// demo.ts let a = "初始化為字符串內容" a = 10 console.log(a)
編譯ts文件
tsc demo.ts
此處回生成demo.js文件,同時控制臺報警告信息:error TS2322: Type "10" is not assignable to type "string". 說明TS對變量類型進行了校驗,但并未阻止編譯器生成最終的js代碼。TS類型推斷
// 定義變量,并約束變量類型 let age: number = 20 let flag: Boolean = true
TS允許我們給變量設置一個類型,但是此種寫法太麻煩。TS提供了便捷的類型推斷機制,相當于在給變量賦初始值時就約束了變量的類型。
// 上面的代碼改造 let age = 20 // 數值類型 let flag = true // 布爾值類型
那么,什么時候需要給變量設置類型呢?聲明變量,但沒有設置其初始值的時候!接口如果沒有給變量設置類型,那么它的類型會被自動設置為any,意思為接受任何類型的值。
在TS中,有兩種接口概念:
第一種:給變量設置類型,是對一個對象必須包含的屬性和方法的描述interface Person { age: number, name: string } function printName (person: Person) { console.log(person.name) } const john = { name: "john", age: 21 } const mary = { name: "mary", age: 20, phone: "123456" } printName(john) printName(mary)
執(zhí)行tsc編譯,木有任何問題。但是小伙伴可能會比較奇怪,對象mary中屬性多了個phone,但是并未影響代碼的執(zhí)行。第二種:TS接口的概念和面向對象編程相關鴨子類型概念:如果它看起來像鴨子,像鴨子一樣游泳,像鴨子一樣叫,那么它一定是一只鴨子!
變量mary的行為與Person接口定義的一樣,那么它就是一個Person。
接口視為一份合約,在合約里可以定義這份合約的類或接口的行為
interface Comparable { compareTo (b): number } class myObject implements Comparable { age: number compareTo(b): number { if (this.age === b.age) { return 0 } return this.age > b.age ? 1 : -1 } } let obj = new MyObject() obj.age = 10 let res = obj.compareTo(20) console.log(res) // -1
Comparable接口告訴MyObject類,它需要實現一個叫做compareTo的方法,并且該方法接收一個參數。泛型
對數據結構和算法作用強大的TS特性是泛型這一概念
interface Comparable后記{ compareTo (b: T): number } class MyObject implements Comparable { age: number compareTo(b: MyObject): number { if (this.age === b.age) { return 0 } return this.age > b.age ? 1 : -1 } } let obj = new MyObject() obj.age = 10 let obj2 = new MyObject() obj2.age = 20 let res = obj.compareTo(obj2) console.log(res) // -1
以上就是胡哥今天給大家分享的內容,喜歡的小伙伴記得收藏、轉發(fā)、點擊右下角按鈕在看,推薦給更多小伙伴呦,歡迎多多留言交流...
胡哥有話說,一個有技術,有情懷的胡哥!京東開放平臺首席前端攻城獅。與你一起聊聊大前端,分享前端系統(tǒng)架構,框架實現原理,最新最高效的技術實踐!
長按掃碼關注,更帥更漂亮呦!關注胡哥有話說公眾號,可與胡哥繼續(xù)深入交流呦!
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/106694.html
摘要:定場詩馬瘦毛長蹄子肥,兒子偷爹不算賊,瞎大爺娶個瞎大奶奶,老兩口過了多半輩,誰也沒看見誰前言本章為重讀學習數據結構與算法第三版的系列文章,主要講述隊列數據結構雙端隊列數據結構以及隊列相關應用。 定場詩 馬瘦毛長蹄子肥,兒子偷爹不算賊,瞎大爺娶個瞎大奶奶,老兩口過了多半輩,誰也沒看見誰! 前言 本章為重讀《學習JavaScript數據結構與算法-第三版》的系列文章,主要講述隊列數據結構、...
摘要:定場詩守法朝朝憂悶,強梁夜夜歡歌損人利己騎馬騾,正值公平挨餓修橋補路瞎眼,殺人放火兒多我到西天問我佛,佛說我也沒轍前言讀學習數據結構與算法第章數組,本小節(jié)將繼續(xù)為各位小伙伴分享數組的相關知識數組的新功能。 定場詩 守法朝朝憂悶,強梁夜夜歡歌; 損人利己騎馬騾,正值公平挨餓; 修橋補路瞎眼,殺人放火兒多; 我到西天問我佛,佛說:我也沒轍! 前言 讀《學習JavaScript數據結構與算法...
摘要:此處應該有掌聲前言讀學習數據結構與算法第章數組,本節(jié)將為各位小伙伴分享數組的相關知識概念創(chuàng)建方式常見方法以及數組的新功能。數組數組是最簡單的內存數據結構,用于存儲一系列同一種數據類型的值。 定場詩 大將生來膽氣豪,腰橫秋水雁翎刀。 風吹鼉鼓山河動,電閃旌旗日月高。 天上麒麟原有種,穴中螻蟻豈能逃。 太平待詔歸來日,朕與先生解戰(zhàn)袍。 此處應該有掌聲... 前言 讀《學習JavaScrip...
摘要:前言本章為重讀學習數據結構與算法的系列文章,該章節(jié)主要講述數據結構鏈表,以及實現鏈表的過程和原理。鏈表,是存儲有序的元素集合。鏈表中的元素在內存中并不是連續(xù)放置的,每個元素由一個存儲自身的元素節(jié)點和一個指向下一個元素的引用指針或鏈接組成。 定場詩 傷情最是晚涼天,憔悴廝人不堪言; 邀酒摧腸三杯醉.尋香驚夢五更寒。 釵頭鳳斜卿有淚,荼蘼花了我無緣; 小樓寂寞新雨月.也難如鉤也難圓。 前言...
摘要:詞法分析對構成源程序的字符流進行掃描然后根據構詞規(guī)則識別單詞也稱單詞符號或符號。語義分析是編譯過程的一個邏輯階段語義分析的任務是對結構上正確的源程序進行上下文有關性質的審查進行類型審查,審查抽象語法樹是否符合該編程語言的規(guī)則。 1. 文章的內容和主題 我對編譯器的深入了解起源于一條推特中的問題:Angular是如何用Angular預先編譯器(AOT)對靜態(tài)代碼進行解析工作的。在進行一些...
閱讀 2919·2021-11-19 09:40
閱讀 3604·2021-10-09 09:43
閱讀 2687·2021-09-22 15:31
閱讀 1739·2021-07-30 15:31
閱讀 791·2019-08-30 15:55
閱讀 3270·2019-08-30 15:54
閱讀 1171·2019-08-30 11:26
閱讀 1919·2019-08-29 13:00