① HBuilder如何配置jsx預編譯器
前去官網下載HBuilder
解壓、創建快捷方式
安裝插件
配置外部伺服器
5
瀏覽器運行URL,一定要是apache項目的主目錄
② [轉載]如何使用PS調片動作---atn文件,jsx文件-腳本編
Frames.atn是PHOTOSHOP里的「畫框」動作集,PHOTOSHOP預設的很多,可另下載也可自己錄制添加新的動作,中文版PHOTOSHOP里"畫框.atn" 舉例,一鍵盛夏變金秋裝載步驟: 1.首先調出動作面板:窗口--顯示動作 2.裝載"畫框"動作集:點擊動作面板右上角(關閉按鈕下面)帶箭頭小圓按鈕,出現菜單 3.選擇菜單中"畫框.atn"裝載畫框動作到動作面板 4.使用時注意去掉不想應用的動作指令前的小勾(比如固定的默認動作和畫框集中不用的動作) 如果對動作不熟最好不播放動作(拉開該動作查看詳細步驟能得更多啟發)創意也更自由點 動作一般來說只是針對簡單的批量處理JSX文件的用法在Photoshop中給圖片加上EXIF信息的方法:先將本文件解壓至Photoshop的安裝目錄,如: C:Program FilesAdobeAdobe Photoshop CS5PresetsScripts下,重啟Photoshop。在「文件」-「腳本」下可以看到這個選項,打開照片,運行這個選項即可 Adobe Photoshop最強有力的工具之一根本不是圖像編輯工具,而是「腳本」(Actions)功能。該功能的使用方法其實很簡單,但遺憾的是,Photoshop的新用戶很少有人知道這一功能的存在,甚至把它閑置不用。Photoshop的新用戶都非常急於立即開始進行編輯,因此他們僅僅使用最基本的編輯工具,並且努力學習該軟體的大量功能。藉助於教學材料和提示信息,經過反復試驗摸索,他們對程序越來越精通。這時,這些用戶就開始使用插件濾鏡了,以得到更豐富的效果。市場上有許多這樣的濾鏡,從互聯網上也可以免費下載一些。這些濾鏡有各種各樣的控制參數,允許你調節濾鏡的作用效果。一些濾鏡專門用於文件的壓縮,另一些濾鏡可以為文本對象製作特殊效果,還有一些濾鏡可以為整幅圖製作特殊效果。問題是"要想製作某種效果,可能需要多個步驟。除非你做大量的筆記,或者記憶力極好,否則,再次重復某種效果幾乎是不可能的。這時,就需要使用到「腳本」(Actions)功能了。它位於Photoshop主界面的頂端的下拉窗口中。「腳本」程序的工作方式與文字處理軟體中的「宏」一樣。「宏」是被錄制在文件中的一系列功能的組合,可以通過熱鍵來啟動。 「腳本」可以將Photoshop的編輯工具和插件濾鏡組合在一個文件中,並只需點擊一次滑鼠即可啟動。在這些「腳本」中,有些能夠實現50多項功能,使用了多個插件濾鏡,並加入了幾十個參數。即便你能夠記住實現某種效果的方法,但要想每次都把各個功能中的參數選正確就不是一件容易的事情。在這方面,「腳本」為你節省了大量時間。 「腳本」主要用於重復性的任務或用於製作非常復雜的特殊效果。要建立一個新的「腳本」,只需單擊「新腳本」(New Action)按鈕。此時,有一個紅色的方框表示當前處於錄制腳本的狀態。當你運行完所有的功能或插件後,停止錄制就可以了。每一個「腳本」都有一個特定的名字,並被添加到腳本清單中。下一次當你想再使用上述組合效果時,只需啟動這一「腳本」,所有的效果就會自動載入給圖像。為了幫助你更好地理解「腳本」,我們以編輯照片為例把「腳本」的使用方法介紹一下。其中大部分方法都是反復試驗摸索而得到的,最終把這些方法存儲為「腳本」。我們將先執行一些重復性的任務,然後再製作更復雜的「腳本」。減輕顆粒 當你處理一幅用感光速度較高的膠片拍攝的照片時,就可以使用「減輕顆粒腳本」(Grain Rediuction)。這一腳本先使用了去斑點濾鏡(Despeckle),然後又使用了銳化濾鏡(Sharpen)。雖然前一個濾鏡能夠去除大量的顆粒,但卻會同時將圖像變模糊。因此,還需要再使用銳化濾鏡。這樣,圖像清晰如初,但顆粒現象卻減輕了。文件的轉換 你需要使用的另一個腳本即所謂「MacTiff 腳本」。我們平時都使用PC機編輯圖像,而我們與之打交道的大多數雜志社卻都使用Mac 機。當我們把一篇文章中的所有圖像都製作好後,需要使用「批處理腳本」對一組圖像進行處理。此時,你只須坐在那裡,看著這個腳本打開一幅幅圖像,將其轉換成Tiff文件,再將其設置成Mac格式,最後保存並關閉它們。誰說PC和Mac勢不兩立呢? 當我們需要將大量的圖像出售給其他公司用於製作教學CD時,可以使用一個專門製作的腳本。這個腳本可以將大量圖像的尺寸減少到其原來的25%,再將它們銳化,最後將它們轉換成為Mac的Tiff文件。這一腳本能夠輕松地將數據總量超過650MB的多個文件處理成一套新的CD圖像。在腳本工作的時候,你就有時間去做其他事情了。在腳本菜單中,還有幾個版本的JPEG、Wavelet、Fractal等壓縮設置。當你歸檔保存圖像時,可以打開批處理腳本並開始轉換過程。這樣就無需使用單獨的文件轉換軟體來轉換文件了,而是可以一直在Photoshop中工作(一些文件轉換軟體並不完全與Photoshop兼容,對於Tiff文件尤其如此)。顏色-Gamma值校正 有時,一批圖像會帶有相同和色偏傾向或不良的反差狀況,這通常是由於掃描質量或膠片的顯示加工質量不好而造成的。由於這一批圖像有著共同的缺點,你就可以建立一個專門的腳本,一次完成對它們的修整。調出第一幅圖像,並錄制對它的修整過程。當完成所有修整操作後,停止錄制,它就會被保存在腳本菜單中了。然後,選擇批處理腳本,並將剛剛製作好的腳本應用於所有的圖像。於是,所有的圖像轉瞬間就都象第一幅圖像那樣得到了修整。如果以後再遇到相似的情況,甚至可以跳過製作腳本的步驟,而直接對待處理的圖像使用該腳本。縮略預覽圖標 其他程序所製作出的圖像可能沒有縮略預覽圖標。為了避免猜測圖像的內容,可以使用「縮略圖標腳本」。這一腳本可以把一組文件打開,並將它們存儲在一個復制目錄中。當所有的圖像都已轉存一遍,且縮略圖標都已形成,就可以安全地刪除第一個目錄了。有時,直立的圖像可能會被橫向放置。此時,再使用第二個腳本,把這些文件打開,待旋轉後再次存儲就可以了。內存控制 Adobe Photoshop允許你撤消先前的操作。當你對一幅圖像進行操作時,Photoshop會在內存中保存關於圖層、剪切板和濾鏡的先前狀態,以防你想撤消一步操作。如果你同時編輯多幅圖像,計算機的內存就會不夠用,因而需要把數據暫時轉移到硬碟中。這樣,系統的運行速度就會降低。清空內存需要多個步驟。當你編輯圖像時,可以利用特定的腳本自動清空內存。該腳本的工作速度非常快,可以使你的工作速度總是保持最快。特殊效果 插件濾鏡的組合可以製作霓虹燈文本、透視效果的陰影、爆炸物體、變幻莫測的背景圖案以及其他許多效果,從而擴展了你的創造潛力。學習製作這些效果的方法的最好途徑是上網,並以「Photoshop腳本」為關鍵詞進行搜索。大量的網站都提供Photoshop插件、濾鏡和腳本。其中一些產品是短期測試版,一些是免費的。它們的最大優點是文件數據量非常小,你可以在不到一小時的時間里下載十多個這類產品。
③ 原來Babel 能直接編譯 JSX.官方用的是哪個
習慣了WebStorm的話..我就假設題主會用Node.js和npm啦~一句話總結:用WebStorm自帶的FileWatcher功能+Babel實現自動轉換ECMAScript6代碼為ES5代碼我是這么配置的..就先新建一個EmptyProject,然後在src目錄下新建了一個main.js;//這一步不是必須的只是剛上手的話從空項目開始自己配置會少很多干擾Then..進入設置,把JavaScriptlanguageversion改成ECMAScript6;再Then..寫一段ES6代碼'usestrict';//node直接運行ES6代碼時,如使用了ES6的一些關鍵字,比如let,就需要嚴格模式,否則會報錯//這是沒有嚴格模式時候的錯誤提示//SyntaxError:Block-scopeddeclarations(let,const,function,class)*fibs(){//GeneratorFunctionleta=0;letb=1;while(true){yielda;//[a,b]=[b,a+b];b=a+b;a=b-a;}}let[first,second,third,fourth,fifth,sixth]=fibs();console.log(first,second,third,fourth,fifth,sixth);現在IDE會出現一個Filewatcher提示條先別點Addwatcher!我們要先去裝babel~首先在根目錄新建一個package.json{"name":"test-project","version":"1.0.0"}然後打開IDE的Terminal,安裝babel-clinpminstall--save-devbabel-cliGood!現在可以去點Addwatcher啦,點完之後會彈出一個框,其中大部分設置IDE都幫你搞定了下面第三行,Program那一項,填$ProjectFileDir$/node_moles/.bin/babel然後點OK,這個時候你就會發現左邊多出來一個main-compiled.js文件啦但是還沒搞定!現在只是搞定了自動轉換的功能,系統默認把ES6compile成了ES6..(你應該會發現compile出來的東西跟原來的一樣..Generator函數並沒有被轉換成ES5的格式)所以我們需要安裝Babel的preset以正確識別ES6代碼;和剛才一樣,在npm安裝babel的ES6的presetnpminstall--save-devbabel-preset-es2015在根目錄下新建一個.babelrc文件(就是babel在當前項目的配置文件),寫上{"presets":["es2015"]}OK搞定!保存再回去看一下main-compiled.js應該就變成這個樣子啦,現在你在main.js里直接寫ES6代碼,IDE都會自動compile成ES5的代碼在這里啦~注意:想直接用Node.js運行ES6代碼還是有些問題..因為這段代碼用的ES6的解構賦值Node.js還未完全支持,需要在運行的時候加入一些tags(以開啟Node.js的相關試驗特性),具體可以參考Node.js官網對ES6的說明:ECMAScript2015(ES6)。
④ TypeScript 入門指南
新系列 深入淺出TypeScript 來了,本系列至少20+篇。本文為第一篇,來介紹一下TypeScript 以及常見的類型。
TypeScript是一門由微軟推出的開源的、跨平台的編程語言。它是JavaScript的超集,擴展了 JavaScript 的語法,最終會被編譯為JavaScript代碼。
TypeScript的主要特性:
TypeScript 主要是為了實現以下兩個目標:
下面就來看看這兩個目標是如何實現的。
為什麼要給JavaScript加上類型呢?
我們知道,JavaScript是一種輕量級的解釋性腳本語言。也是弱類型、動態類型語言,允許隱式轉換,只有運行時才能確定變數的類型。正是因為在運行時才能確定變數的類型,JavaScript代碼很多錯誤在運行時才能發現。TypeScript在JavaScript的基礎上,包裝了類型機制,使其變身成為 靜態類型 語言。在 TypeScript 中,不僅可以輕易復用 JavaScript 的代碼、最新特性,還能使用可選的靜態類型進行檢查報錯,使得編寫的代碼更健壯、更易於維護。
下面是 JavaScript 項目中最常見的十大錯誤,如果使用 TypeScript,那麼在 編寫階段 就可以發現並解決很多 JavaScript 錯誤了:
類型系統能夠提高代碼的質量和可維護性,經過不斷的實踐,以下兩點尤其需要注意:
可以認為,在所有操作符之前,TypeScript 都能檢測到接收的類型(在代碼運行時,操作符接收的是實際數據;在靜態檢測時,操作符接收的則是類型)是否被當前操作符所支持。當 TypeScript 類型檢測能力覆蓋到所有代碼後,任意破壞約定的改動都能被自動檢測出來,並提出類型錯誤。因此,可以放心地修改、重構業務邏輯,而不用擔憂因為考慮不周而犯下低級錯誤。
在一些語言中,類型總是有一些不必要的復雜的存在方式,而 TypeScript 盡可能地降低了使用門檻,它是通過如下方式來實現的。
TypeScript 與 JavaScript 本質並無區別,我們可以將 TypeScipt 理解為是一個添加了類型註解的 JavaScript,為JavaScript代碼提供了編譯時的類型安全。
實際上,TypeScript 是一門「 中間語言 」,因為它最終會轉化為JavaScript,再交給瀏覽器解釋、執行。不過 TypeScript 並不會破壞 JavaScript 原有的體系,只是在 JavaScript 的基礎上進行了擴展。
准確的說,TypeScript 只是將JavaScript中的方法進行了標准化處理:
這段代碼在TypeScript中就會報錯,因為TS會知道a是一個數字類型,不能將其他類型的值賦值給a,這種類型的推斷是很有必要的。
上面說了,TypeScript會盡可能安全的推斷類型。我們也可以使用類型注釋,以實現以下兩件事:
在一些語言中,類型總是有一些不必要的復雜的存在方式,而 TypeScript 的類型是結構化的。比如下面的例子中,函數會接受它所期望的參數:
為了便於把 JavaScript 代碼遷移至 TypeScript,即使存在編譯錯誤,在默認的情況下,TypeScript 也會盡可能的被編譯為 JavaScript 代碼。因此,我們可以將JavaScript代碼逐步遷移至 TypeScript。
雖然 TypeScript 是 JavaScript 的超集,但它始終緊跟ECMAScript標准,所以是支持ES6/7/8/9 等新語法標準的。並且,在語法層面上對一些語法進行了擴展。TypeScript 團隊也正在積極的添加新功能的支持,這些功能會隨著時間的推移而越來越多,越來越全面。
雖然 TypeScript 比較嚴謹,但是它並沒有讓 JavaScript 失去其靈活性。TypeScript 由於兼容 JavaScript 所以靈活度可以媲美 JavaScript,比如可以在任何地方將類型定義為 any(當然,並不推薦這樣使用),畢竟 TypeScript 對類型的檢查嚴格程度是可以通過 tsconfig.json 來配置的。
在搭建TypeScript環境之前,先來看看適合TypeScript的IDE,這里主要介紹Visual Studio Code,筆者就一直使用這款編輯器。
VS Code可以說是微軟的親兒子了,其具有以下優勢:
因為 VS Code 中內置了特定版本的 TypeScript 語言服務,所以它天然支持 TypeScript 語法解析和類型檢測,且這個內置的服務與手動安裝的 TypeScript 完全隔離。因此, VS Code 支持在內置和手動安裝版本之間動態切換語言服務,從而實現對不同版本的 TypeScript 的支持。
如果當前應用目錄中安裝了與內置服務不同版本的 TypeScript,我們就可以點擊 VS Code 底部工具欄的版本號信息,從而實現 「use VS Code's Version」 和 「use Workspace's Version」 兩者之間的隨意切換。
除此之外,VS Code 也基於 TypeScript 語言服務提供了准確的代碼自動補全功能,並顯示詳細的類型定義信息,大大的提升了我們的開發效率。
1)全局安裝TypeScript:
2)初始化配置文件:
執行之後,項目根目錄會出現一個 tsconfig.json 文件,裡麵包含ts的配置項(可能因為版本不同而配置略有不同)。
可以在 package.json 中加入script命令:
3)編譯ts代碼:
TSLint 是一個通過 tslint.json 進行配置的插件,在編寫TypeScript代碼時,可以對代碼風格進行檢查和提示。如果對代碼風格有要求,就需要用到TSLint了。其使用步驟如下: (1)在全局安裝TSLint:
(2)使用TSLint初始化配置文件:
執行之後,項目根目錄下多了一個 tslint.json 文件,這就是TSLint的配置文件了,它會根據這個文件對代碼進行檢查,生成的 tslint.json 文件有下面幾個欄位:
這些欄位的含義如下;
在說TypeScript數據類型之前,先來看看在TypeScript中定義數據類型的基本語法。
在語法層面,預設類型註解的 TypeScript 與 JavaScript 完全一致。因此,可以把 TypeScript 代碼的編寫看作是為 JavaScript 代碼添加類型註解。
在 TypeScript 語法中,類型的標注主要通過類型後置語法來實現:「 變數: 類型 」
在 JavaScript 中,原始類型指的是 非對象且沒有方法 的數據類型,包括:number、boolean、string、null、undefined、symbol、bigInt。
它們對應的 TypeScript 類型如下:
JavaScript原始基礎類型TypeScript類型 numbernumber booleanboolean stringstring nullnull undefinendefined symbolsymbol bigIntbigInt
需要注意 number 和 Number 的區別:TypeScript中指定類型的時候要用 number ,這是TypeScript的類型關鍵字。而 Number 是 JavaScript 的原生構造函數,用它來創建數值類型的值,這兩個是不一樣的。包括 string 、 boolean 等都是TypeScript的類型關鍵字,而不是JavaScript語法。
TypeScript 和 JavaScript 一樣,所有數字都是 浮點數 ,所以只有一個 number 類型。
TypeScript 還支持 ES6 中新增的二進制和八進制字面量,所以 TypeScript 中共支持 2、8、10和16 這四種進制的數值:
字元串類型可以使用單引號和雙引號來包裹內容,但是如果使用 Tslint 規則,會對引號進行檢測,使用單引號還是雙引號可以在 Tslint 規則中進行配置。除此之外,還可以使用 ES6 中的模板字元串來拼接變數和字元串會更為方便。
類型為布爾值類型的變數的值只能是true或者false。除此之外,賦值給布爾值的值也可以是一個計算之後結果為布爾值的表達式:
在 JavaScript 中,undefined和 null 是兩個基本數據類型。在 TypeScript 中,這兩者都有各自的類型,即 undefined 和 null,也就是說它們既是實際的值,也是類型。這兩種類型的實際用處不是很大。
注意,第一行代碼可能會報一個tslint的錯誤: Unnecessary initialization to 'undefined' ,就是不能給一個變數賦值為undefined。但實際上給變數賦值為undefined是完全可以的,所以如果想讓代碼合理化,可以配置tslint,將" no-unnecessary-initializer "設置為 false 即可。
默認情況下,undefined 和 null 是所有類型的子類型,可以賦值給任意類型的值,也就是說可以把 undefined 賦值給 void 類型,也可以賦值給 number 類型。當在 tsconfig.json 的"compilerOptions"里設置為 "strictNullChecks": true 時,就必須嚴格對待了。這時 undefined 和 null 將只能賦值給它們自身或者 void 類型。這樣也可以規避一些錯誤。
BigInt是ES6中新引入的數據類型,它是一種內置對象,它提供了一種方法來表示大於 2- 1 的整數,BigInt可以表示任意大的整數。
使用 BigInt 可以安全地存儲和操作大整數,即使這個數已經超出了JavaScript構造函數 Number 能夠表示的安全整數范圍。
我們知道,在 JavaScript 中採用雙精度浮點數,這導致精度有限,比如 Number.MAX_SAFE_INTEGER 給出了可以安全遞增的最大可能整數,即 2- 1 ,來看一個例子:
可以看到,最終返回了true,這就是超過精讀范圍造成的問題,而 BigInt 正是解決這類問題而生的:
這里需要用 BigInt(number) 把 Number 轉化為 BigInt ,同時如果類型是 BigInt ,那麼數字後面需要加 n 。
在TypeScript中, number 類型雖然和 BigInt 都表示數字,但是實際上兩者類型是完全不同的:
symbol我們平時用的比較少,所以可能了解也不是很多,這里就詳細來說說symbol。
symbol 是 ES6 新增的一種基本數據類型,它用來表示獨一無二的值,可以通過 Symbol 構造函數生成。
注意:Symbol 前面不能加 new關鍵字,直接調用即可創建一個獨一無二的 symbol 類型的值。
可以在使用 Symbol 方法創建 symbol 類型值的時候傳入一個參數,這個參數需要是一個字元串。如果傳入的參數不是字元串,會先自動調用傳入參數的 toString 方法轉為字元串:
上面代碼的第三行可能會報一個錯誤:This condition will always return 'false' since the types 'unique symbol' and 'unique symbol' have no overlap. 這是因為編譯器檢測到這里的 s1 === s2 始終是false,所以編譯器提醒這代碼寫的多餘,建議進行優化。
上面使用Symbol創建了兩個symbol對象,方法中都傳入了相同的字元串,但是兩個symbol值仍然是false,這就說明了 Symbol 方法會返回一個獨一無二的值。Symbol 方法傳入的這個字元串,就是方便我們區分 symbol 值的。可以調用 symbol 值的 toString 方法將它轉為字元串:
在TypeScript中使用symbol就是指定一個值的類型為symbol類型:
在ES6中,對象的屬性是支持表達式的,可以使用於一個變數來作為屬性名,這對於代碼的簡化有很多用處,表達式必須放在大括弧內:
symbol 也可以作為屬性名,因為symbol的值是獨一無二的,所以當它作為屬性名時,不會與其他任何屬性名重復。當需要訪問這個屬性時,只能使用這個symbol值來訪問(必須使用方括弧形式來訪問):
在使用obj.name訪問時,實際上是字元串name,這和訪問普通字元串類型的屬性名是一樣的,要想訪問屬性名為symbol類型的屬性時,必須使用方括弧。方括弧中的name才是我們定義的symbol類型的變數name。
使用 Symbol 類型值作為屬性名,這個屬性是不會被 for…in遍歷到的,也不會被 Object.keys() 、 Object.getOwnPropertyNames() 、 JSON.stringify() 等方法獲取到:
雖然這些方法都不能訪問到Symbol類型的屬性名,但是Symbol類型的屬性並不是私有屬性,可以使用 Object.getOwnPropertySymbols 方法獲取對象的所有symbol類型的屬性名:
除了這個方法,還可以使用ES6提供的 Reflect 對象的靜態方法 Reflect.ownKeys ,它可以返回所有類型的屬性名,Symbol 類型的也會返回:
Symbol 包含兩個靜態方法, for 和 keyFor 。 1)Symbol.for()
用Symbol創建的symbol類型的值都是獨一無二的。使用 Symbol.for 方法傳入字元串,會先檢查有沒有使用該字元串調用 Symbol.for 方法創建的 symbol 值。如果有,返回該值;如果沒有,則使用該字元串新創建一個。使用該方法創建 symbol 值後會在全局范圍進行注冊。
上面代碼中,創建了一個iframe節點並把它放在body中,通過這個 iframe 對象的 contentWindow 拿到這個 iframe 的 window 對象,在 iframe.contentWindow上添加一個值就相當於在當前頁面定義一個全局變數一樣。可以看到,在 iframe 中定義的鍵為 TypeScript 的 symbol 值在和在當前頁面定義的鍵為'TypeScript'的symbol 值相等,說明它們是同一個值。
2)Symbol.keyFor() 該方法傳入一個 symbol 值,返回該值在全局注冊的鍵名:
看完簡單的數據類型,下面就來看看比較復雜的數據類型,包括JavaScript中的數組和對象,以及TypeScript中新增的元組、枚舉、Any、void、never、unknown。
在 TypeScript 中有兩種定義數組的方式:
以上兩種定義數組類型的方式雖然本質上沒有任何區別,但是更推薦使用第一種形式來定義。一方面可以避免與 JSX 語法沖突,另一方面可以減少代碼量。
注意,這兩種寫法中的 number 指定的是數組元素的類型,也可以在這里將數組的元素指定為其他任意類型。如果要指定一個數組里的元素既可以是數值也可以是字元串,那麼可以使用這種方式: number|string[] 。
在JavaScript中,object是引用類型,它存儲的是值的引用。在TypeScript中,當想讓一個變數或者函數的參數的類型是一個對象的形式時,可以使用這個類型:
可以看到,當給一個對象類型的變數賦值一個對象時,就會報錯。對象類型更適合以下場景:
在 JavaScript 中並沒有元組的概念,作為一門動態類型語言,它的優勢是支持多類型元素數組。但是出於較好的擴展性、可讀性和穩定性考慮,我們通常會把不同類型的值通過鍵值對的形式塞到一個對象中,再返回這個對象,而不是使用沒有任何限制的數組。TypeScript 的元組類型正好彌補了這個不足,使得定義包含固定個數元素、每個元素類型未必相同的數組成為可能。
元組可以看做是數組的擴展,它表示已知元素數量和類型的數組,它特別適合用來實現多值返回。確切的說,就是已知數組中每一個位置上的元素的類型,可以通過元組的索引為元素賦值::
可以看到,定義的arr元組中,元素個數和元素類型都是確定的,當為arr賦值時,各個位置上的元素類型都要對應,元素個數也要一致。
當訪問元組元素時,TypeScript也會對元素做類型檢查,如果元素是一個字元串,那麼它只能使用字元串方法,如果使用別的類型的方法,就會報錯。
在TypeScript 新的版本中,TypeScript會對元組做越界判斷。超出規定個數的元素稱作越界元素,元素賦值必須類型和個數都對應,不能超出定義的元素個數。
這里定義了介面 Tuple ,它繼承數組類型,並且數組元素的類型是 number 和 string 構成的聯合類型,這樣介面 Tuple 就擁有了數組類型所有的特性。並且指定索引為0的值為 string 類型,索引為1的值為 number 類型,同時指定 length 屬性的類型字面量為 2,這樣在指定一個類型為這個介面 Tuple 時,這個值必須是數組,而且如果元素個數超過2個時,它的length就不是2是大於2的數了,就不滿足這個介面定義了,所以就會報錯;當然,如果元素個數不夠2個也會報錯,因為索引為0或1的值缺失。
TypeScript 在 ES 原有類型基礎上加入枚舉類型,使得在 TypeScript 中也可以給一組數值賦予名字,這樣對開發者比較友好。枚舉類型使用enum來定義:
上面定義的枚舉類型的Roles,它有三個值,TypeScript會為它們每個值分配編號,默認從0開始,在使用時,就可以使用名字而不需要記數字和名稱的對應關系了:
除此之外,還可以修改這個數值,讓SUPER_ADMIN = 1,這樣後面的值就分別是2和3。當然還可以給每個值賦予不同的、不按順序排列的值:
我們可以將一個值定義為any類型,也可以在定義數組類型時使用any來指定數組中的元素類型為任意類型:
any 類型會在對象的調用鏈中進行傳導,即any 類型對象的任意屬性的類型都是 any,如下代碼所示:
需要注意:不要濫用any類型,如果代碼中充滿了any,那TypeScript和JavaScript就毫無區別了,所以除非有充足的理由,否則應該盡量避免使用 any ,並且開啟禁用隱式 any 的設置。
void 和 any 相反,any 是表示任意類型,而 void 是表示沒有類型,就是什麼類型都不是。這在 定義函數,並且函數沒有返回值時會用到 :
需要注意: void 類型的變數只能賦值為 undefined 和 null ,其他類型不能賦值給 void 類型的變數。
never 類型指永遠不存在值的類型,它是那些 總會拋出異常 或 根本不會有返回值的函數表達式的返回值 類型,當變數被永不為真的類型保護所約束時,該變數也是 never 類型。
下面的函數,總是會拋出異常,所以它的返回值類型是never,用來表明它的返回值是不存在的:
never 類型是任何類型的子類型,所以它可以賦值給任何類型;而沒有類型是 never 的子類型,所以除了它自身以外,其他類型(包括 any 類型)都不能為 never 類型賦值。
上面代碼定義了一個立即執行函數,函數體是一個死循環,這個函數調用後的返回值類型為 never,所以賦值之後 neverVariable 的類型是 never 類型,當給neverVariable 賦值 123 時,就會報錯,因為除它自身外任何類型都不能賦值給 never 類型。
基於 never 的特性,我們可以把 never 作為介面類型下的屬性類型,用來禁止操作介面下特定的屬性:
可以看到,無論給 props.name 賦什麼類型的值,它都會提示類型錯誤,這就相當於將 name 屬性設置為了只讀 。
unknown 是TypeScript在3.0版本新增的類型,主要用來描述類型並不確定的變數。它看起來和any很像,但是還是有區別的,unknown相對於any更安全。
對於any,來看一個例子:
上面這些語句都不會報錯,因為value是any類型,所以後面三個操作都有合法的情況,當value是一個對象時,訪問name屬性是沒問題的;當value是數值類型的時候,調用它的toFixed方法沒問題;當value是字元串或數組時獲取它的length屬性是沒問題的。
當指定值為unknown類型的時候,如果沒有 縮小類型範圍 的話,是不能對它進行任何操作的。總之,unknown類型的值不能隨便操作。那什麼是類型範圍縮小呢?下面來看一個例子:
這里由於把value的類型縮小為Date實例的范圍內,所以進行了value.toISOString(),也就是使用ISO標准將 Date 對象轉換為字元串。
使用以下方式也可以縮小類型範圍:
關於 unknown 類型,在使用時需要注意以下幾點:
在實際使用中,如果有類型無法確定的情況,要盡量避免使用 any,因為 any 會丟失類型信息,一旦一個類型被指定為 any,那麼在它上面進行任何操作都是合法的,所以會有意想不到的情況發生。因此如果遇到無法確定類型的情況,要先考慮使用 unknown。
⑤ 如何用 Bower 編譯 jsx
1.安裝node,因為ts的編譯器是js/ts寫的; 安裝node後同時獲得npm命令,這是nodejs世界裡的包管理器(也可以看作node的app商店); 2.安裝vs 2015或者vs code,當然這不是必須的,但是這里強烈推薦寫ts的工具,vs第一,vsc第二; 3.vs自帶了Type...
⑥ js 和 jsx 有什麼區別
js就是前端開發語言,jsx是React框架下用的,要在React框架中的編譯器編譯成js語言才能使用的
⑦ 如何使用react-tools將jsx編譯成JavaScript
1,通過npm安裝react-tools
npm –g react-tools
2,通過cmd進入項目根目錄執行watch命令 jsx --watch src/ build/
src路徑下存放的是jsx文件,編譯後的js存放到build路徑下
3,當目標文件變化以後,自動構建生成新的js文件。
⑧ 如何使用react-tools將jsx編譯成JavaScript
1,通過npm安裝react-tools
npm –g react-tools
2,通過cmd進入項目根目錄執行watch命令 jsx --watch src/ build/
src路徑下存放的是jsx文件,編譯後的js存放到build路徑下
3,當目標文件變化以後,自動構建生成新的js文件。
⑨ 如何使用react-tools將jsx編譯成JavaScript
jsx--watchsrc/build/目前官方已經停止維護 jsx 工具,推薦使用 babel 來替代。
⑩ 如何使用react-tools將jsx編譯成JavaScript
使用react-tools將jsx編譯成JavaScript方法:
1,通過npm安裝react-tools
npm –g react-tools
2,通過cmd進入項目根目錄執行watch命令 jsx --watch src/ build/
src路徑下存放的是jsx文件,編譯後的js存放到build路徑下
3,當目標文件變化以後,自動構建生成新的js文件。