webpack typescript react 組合開發(fā)環(huán)境搭建

1粘姜、新建工程目錄,進(jìn)入目錄掌桩,輸入 npm init -y (-y是yes的意思色乾,不詢問設(shè)置,按照默認(rèn)初始化)窍奋;
2荐健、安裝react/react-dom:npm install --save react react-dom琳袄;
3江场、安裝react和react-dom的聲明文件:npm install --save-dev @types/react @types/react-dom
4窖逗、安裝typescript和相關(guān)loader: npm install --save-dev typescript ts-loader source-map-loader址否;
5碎紊、安裝插件html-webpack-plugin,該插件:npm install --save-dev html-webpack-plugin词爬,該插件是可選的权均,作用是自動生成html叽赊,并自動引入最終打包好的js文件;
6、安裝webpack相關(guān),```npm install --save-dev webpack-dev-server webpack webpack-cli;
7咆课、在項目根目錄創(chuàng)建typescript配置文件tsconfig.json:

{
    "compilerOptions": {
      "sourceMap": true,
      "module": "commonjs",
      "target": "es5",
      "jsx": "react",
    }
  }

8、創(chuàng)建webpack配置文件:webpack.config.js:

const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin')

module.exports = {
    entry: "./src/index.tsx",
    output: {
        filename: '[name].bundle.js',
        path: path.resolve(__dirname, "dist")
    },
    devServer:{
        port: 9001,
        open: true,
        contentBase: "./dist"
    },
    module: {
        rules: [
            {
                test: /\.tsx?$/,
                use: {
                    loader: 'ts-loader'
                },
                exclude: /node_modules/
            },
        ]
    },
    resolve: {
        extensions: [ '.tsx', '.ts', '.js' ]
    },
    plugins: [
        new HtmlWebpackPlugin({
            title: "hello dog",
            hash: false,
            // template: path.resolve(__dirname, "src/index.html")
        }),
    ]
}

9迅栅、編輯package.json读存,在script里增加"start": "webpack-dev-server";
10为流、創(chuàng)建入口文件index.tsx敬察,這里可以愉快的寫代碼了莲祸;
11、npm start運(yùn)行
以下步驟可選抹估。由typescript語法寫的代碼药蜻,經(jīng)過ts-loader可以成功轉(zhuǎn)換為瀏覽器可以識別的js代碼瓷式,也包括jsx語法,因為tsconfig.json中配置了"jsx": "react"。轉(zhuǎn)換jsx語法的任務(wù)也可以交給babel惋砂,只要將jsx指定為preserve,然后指定babel-loader進(jìn)行下一步轉(zhuǎn)化,這個過程需要用到@babel/preset-react預(yù)設(shè)期虾。
12鞠评、安裝babel npm install --save-dev @babel/core @babel/cli @babel/preset-env @babel/preset-react;
13谢澈、添加babel配置文件babel.config.js:

const presets = [
    [
        "@babel/env",
        {
            targets: {
                edge: "17",
                firefox: "60",
                chrome: "67",
                safari: "11.1",
            },
        },
    ],
    [
        "@babel/preset-react"
    ]
];

module.exports = { presets };

presets是按照逆序執(zhí)行的
14、修改webpack.config.js文件,添加babel-loader:

rules: [
            {
                test: /\.tsx?$/,
                loader:['babel-loader','ts-loader'],
                exclude: /node_modules/
            },
        ]
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末数尿,一起剝皮案震驚了整個濱河市右蹦,隨后出現(xiàn)的幾起案子诊杆,更是在濱河造成了極大的恐慌,老刑警劉巖何陆,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件晨汹,死亡現(xiàn)場離奇詭異,居然都是意外死亡贷盲,警方通過查閱死者的電腦和手機(jī)淘这,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來巩剖,“玉大人铝穷,你說我怎么就攤上這事∏蚣埃” “怎么了氧骤?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長吃引。 經(jīng)常有香客問我筹陵,道長,這世上最難降的妖魔是什么镊尺? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任朦佩,我火速辦了婚禮,結(jié)果婚禮上庐氮,老公的妹妹穿的比我還像新娘语稠。我一直安慰自己,他們只是感情好弄砍,可當(dāng)我...
    茶點故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布仙畦。 她就那樣靜靜地躺著,像睡著了一般音婶。 火紅的嫁衣襯著肌膚如雪慨畸。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天衣式,我揣著相機(jī)與錄音寸士,去河邊找鬼檐什。 笑死,一個胖子當(dāng)著我的面吹牛弱卡,可吹牛的內(nèi)容都是我干的乃正。 我是一名探鬼主播,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼婶博,長吁一口氣:“原來是場噩夢啊……” “哼瓮具!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起凡人,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤搭综,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后划栓,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體兑巾,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年忠荞,在試婚紗的時候發(fā)現(xiàn)自己被綠了蒋歌。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,096評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡委煤,死狀恐怖堂油,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情碧绞,我是刑警寧澤府框,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站讥邻,受9級特大地震影響迫靖,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜兴使,卻給世界環(huán)境...
    茶點故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一系宜、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧发魄,春花似錦盹牧、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至苹粟,卻和暖如春有滑,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背六水。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工俺孙, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人掷贾。 一個月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓睛榄,卻偏偏與公主長得像,于是被迫代替她去往敵國和親想帅。 傳聞我的和親對象是個殘疾皇子场靴,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,037評論 2 355

推薦閱讀更多精彩內(nèi)容