亚洲av午夜福利精品一区人妖,亚洲乱码日产精品a级毛片久久,91精品视频观看,青草青草久热精品视频在线观看

Typescript 內置的模塊導入兼容方式

2020-6-4    seo達人

一、前言

前端的模塊化規范包括 commonJS、AMD、CMD 和 ES6。其中 AMD 和 CMD 可以說是過渡期的產物,目前較為常見的是commonJS 和 ES6。在 TS 中這兩種模塊化方案的混用,往往會出現一些意想不到的問題。


二、import * as

考慮到兼容性,我們一般會將代碼編譯為 es5 標準,于是 tsconfig.json 會有以下配置:


{

 "compilerOptions": {

   "module": "commonjs",

   "target": "es5",

 }

}

代碼編譯后最終會以 commonJS 的形式輸出。

使用 React 的時候,這種寫法 import React from "react" 會收到一個莫名其妙的報錯:


Module "react" has no default export

這時候你只能把代碼改成這樣:import * as React from "react"。

究其原因,React 是以 commonJS 的規范導出的,而 import React from "react" 這種寫法會去找 React 模塊中的 exports.default,而 React 并沒有導出這個屬性,于是就報了如上錯誤。而 import * as React 的寫法會取 module.exports 中的值,這樣使用起來就不會有任何問題。我們來看看 React 模塊導出的代碼到底是怎樣的(精簡過):


...

var React = {

 Children: {

   map: mapChildren,

   forEach: forEachChildren,

   count: countChildren,

   toArray: toArray,

   only: onlyChild

 },


 createRef: createRef,

 Component: Component,

 PureComponent: PureComponent,

 ...

}


module.exports = React;

可以看到,React 導出的是一個對象,自然也不會有 default 屬性。


二、esModuleInterop

為了兼容這種這種情況,TS 提供了配置項 esModuleInterop 和 allowSyntheticDefaultImports,加上后就不會有報錯了:


{

 "compilerOptions": {

   "module": "commonjs",

   "target": "es5",

   "allowSyntheticDefaultImports": true,

   "esModuleInterop": true

 }

}

其中 allowSyntheticDefaultImports 這個字段的作用只是在靜態類型檢查時,把 import 沒有 exports.default 的報錯忽略掉。

而 esModuleInterop 會真正的在編譯的過程中生成兼容代碼,使模塊能正確的導入。還是開始的代碼:


import React from "react";

現在 TS 編譯后是這樣的:


var __importDefault = (this && this.__importDefault) || function (mod) {

   return (mod && mod.__esModule) ? mod : { "default": mod };

};


Object.defineProperty(exports, "__esModule", { value: true });


var react_1 = __importDefault(require("react"));

編譯器幫我們生成了一個新的對象,將模塊賦值給它的 default 屬性,運行時就不會報錯了。


三、Tree Shaking

如果把 TS 按照 ES6 規范編譯,就不需要加上 esModuleInterop,只需要 allowSyntheticDefaultImports,防止靜態類型檢查時報錯。


{

 "compilerOptions": {

   "module": "es6",

   "target": "es6",

   "allowSyntheticDefaultImports": true

 }

}

什么情況下我們會考慮導出成 ES6 規范呢?多數情況是為了使用 webpack 的 tree shaking 特性,因為它只對 ES6 的代碼生效。


順便再發散一下,講講 babel-plugin-component。


import { Button, Select } from 'element-ui'

上面的代碼經過編譯后,是下面這樣的:


var a = require('element-ui');

var Button = a.Button;

var Select = a.Select;

var a = require('element-ui') 會引入整個組件庫,即使只用了其中的 2 個組件。

babel-plugin-component 的作用是將代碼做如下轉換:


// 轉換前

import { Button, Select } from 'element-ui'

// 轉換后

import Button from 'element-ui/lib/button'

import Select from 'element-ui/lib/select'

最終編譯出來是這個樣子,只會加載用到的組件:


var Button = require('element-ui/lib/button');

var Select = require('element-ui/lib/select');

四、總結

本文講解了 TypeScript 是如何導入不同模塊標準打包的代碼的。無論你導入的是 commonJS 還是 ES6 的代碼,萬無一失的方式是把 esModuleInterop 和 allowSyntheticDefaultImports 都配置上。

日歷

鏈接

個人資料

藍藍設計的小編 http://m.skdbbs.com

存檔

亚洲av午夜福利精品一区人妖,亚洲乱码日产精品a级毛片久久,91精品视频观看,青草青草久热精品视频在线观看
<strike id="cy2gs"><menu id="cy2gs"></menu></strike>
  • <del id="cy2gs"><dfn id="cy2gs"></dfn></del>
  • 国产一区二区视频在线观看| 亚洲图片欧美一区| 欧美系列电影免费观看| 欧美国产精品久久| 欧美jizzhd精品欧美喷水 | 欧美区在线观看| 欧美黄色网络| 欧美久久久久免费| 欧美日韩国产高清| 欧美亚男人的天堂| 国产精品美女999| 国产情人节一区| 国产在线播放一区二区三区| 国产一区在线看| 一区二区三区在线观看欧美| 在线观看日韩av| 亚洲精品极品| 宅男精品视频| 午夜亚洲性色视频| 国产欧美日韩在线视频| 国产精品二区影院| 欧美视频不卡| 国产毛片一区| 精品9999| 亚洲精品久久久久中文字幕欢迎你| aa成人免费视频| 亚洲欧美大片| 久久久精品久久久久| 男女精品网站| 久久精品99国产精品| 亚洲午夜91| 欧美专区在线播放| 免费影视亚洲| 欧美午夜激情在线| 国产在线精品二区| 亚洲理论电影网| 亚洲欧美日韩国产| 美女被久久久| 亚洲第一久久影院| 国产日本欧美一区二区三区在线| 国内精品久久久久久影视8| 亚洲高清中文字幕| 中文精品在线| 久久精品国产精品亚洲精品| 欧美不卡视频| 国产精品久久久久久久电影| 久久综合狠狠综合久久综合88| 麻豆成人综合网| 久久亚洲视频| 欧美视频福利| 精品91在线| 一区二区三区国产| 久久人91精品久久久久久不卡| 欧美日韩成人网| 国产在线拍揄自揄视频不卡99| 99re视频这里只有精品| 亚洲高清一区二| 黄色精品一二区| 一区二区日韩精品| 久久露脸国产精品| 国产精品久久久久久久午夜片| 在线精品视频一区二区三四| 亚洲私人影院在线观看| 免费久久精品视频| 国产视频精品xxxx| 久热国产精品| 国产精品乱人伦中文| 国产视频在线观看一区| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 亚洲视频精品| 欧美区在线观看| 国产精品一区二区在线观看不卡 | 国产日韩在线一区| 日韩视频在线永久播放| 久久影院午夜论| 国产欧美日韩一区| 夜夜嗨av一区二区三区| 久久人人爽爽爽人久久久| 亚洲一区二区欧美日韩| 欧美电影免费| 一色屋精品视频在线观看网站| 亚洲综合视频在线| 欧美日韩久久不卡| 91久久久久久久久久久久久| 久久精品九九| 国产欧美日韩一区二区三区在线观看 | 久久久精品tv| 国产精品普通话对白| 日韩视频免费在线| 美日韩丰满少妇在线观看| 国产亚洲一区在线播放| 欧美视频精品一区| 亚洲成色777777女色窝| 99一区二区| 欧美激情第8页| 在线国产日韩| 久久综合精品国产一区二区三区| 国产欧美日韩在线 | 性久久久久久久久久久久| 欧美日韩一区自拍| 亚洲黑丝一区二区| 亚洲美女免费视频| 欧美大片免费久久精品三p | 国产区精品在线观看| 中日韩美女免费视频网址在线观看 | 1024欧美极品| 久久一区二区视频| 极品少妇一区二区三区| 久久精品视频播放| 国产在线精品自拍| 欧美精品观看| 久久影视精品| 激情五月婷婷综合| 久久噜噜亚洲综合| 极品尤物av久久免费看| 久久久久**毛片大全| 国内揄拍国内精品久久| 久久久国产一区二区三区| 激情五月***国产精品| 另类图片国产| 久久免费视频网| 国产亚洲一区在线| 亚洲综合色丁香婷婷六月图片| 欧美午夜精品| 亚洲综合精品四区| 国产精品影音先锋| 久久成人免费电影| 好吊日精品视频| 久久综合久久久久88| **性色生活片久久毛片| 亚洲免费福利视频| 欧美日韩视频一区二区| 狠狠色狠狠色综合日日五| 久久伊人亚洲| 亚洲人体1000| 欧美日韩在线播放一区二区| 亚洲在线免费| 国产亚洲毛片在线| 久久午夜精品| 亚洲人体1000| 欧美三日本三级少妇三2023| 亚洲一区二区精品在线观看| 狂野欧美激情性xxxx| 亚洲二区免费| 欧美久久99| 亚洲欧美三级在线| 激情久久影院| 欧美激情综合在线| 亚洲一区二区三区四区中文 | 国产综合视频| 亚洲大片在线| 欧美成人69av| 在线看一区二区| 欧美猛交免费看| 午夜精品久久久久久久99樱桃 | 黄色一区二区在线观看| 欧美不卡高清| 新狼窝色av性久久久久久| 久久成人18免费观看| 在线看一区二区| 国产精品久久久久久av福利软件| 久久精品二区亚洲w码| 亚洲精品国精品久久99热| 国产精品国产精品国产专区不蜜| 欧美一区三区三区高中清蜜桃| 亚洲第一区在线观看| 欧美亚州一区二区三区 | 国产亚洲日本欧美韩国| 欧美va亚洲va香蕉在线| 亚洲资源在线观看| 亚洲国产精品热久久| 国产精品劲爆视频| 久久亚洲二区| 亚洲一区高清| 伊人久久噜噜噜躁狠狠躁| 欧美日韩一本到| 正在播放亚洲一区| 一本一本久久| 国语精品一区| 欧美日韩一级片在线观看| 久久精品国产综合精品| 日韩亚洲欧美在线观看| 国内成+人亚洲| 国产精品yjizz| 欧美成人免费播放| 欧美一区亚洲| 一本一本久久a久久精品综合麻豆| 最新日韩在线视频| 欧美不卡视频一区发布| 香蕉成人久久| 一本大道久久a久久精二百| 激情另类综合| 国产精品一区二区欧美| 欧美日韩不卡一区| 噜噜噜躁狠狠躁狠狠精品视频| 欧美亚洲视频在线观看| 一区二区三区**美女毛片| 亚洲国产精彩中文乱码av在线播放| 国产农村妇女精品一二区| 欧美丰满高潮xxxx喷水动漫|