一步步創(chuàng)建TypeScript React項目

本文會一步步配置一個React的TypeScript開發(fā)環(huán)境.使用TypeScript能夠很大程度上的提高開發(fā)效率,特別是當您排錯的時候...

本文涉及: TypeScript, Webpack, React, React-route, Webpack-dev-server

安裝Visual Studio Code

Visual Studio Code 官網(wǎng)

創(chuàng)建npm項目

$ npm init

安裝依賴

這里包括整個項目的依賴

npm i --save react react-dom react-router @types/react @types/react-dom @types/react-router
npm i --save-dev typescript awesome-typescript-loader source-map-loader
npm i --save-dev webpack
npm i --save-dev webpack-dev-server
npm link --save webpack webpack-dev-server

創(chuàng)建tsconfig.json

$ touch tsconfig.json

./tsconfig.json 中添加::

{
    "compilerOptions": {
        "outDir": "./build/",
        "sourceMap": true,
        "noImplicitAny": true,
        "module": "commonjs",
        "target": "es5",
        "jsx": "react"
    },
    "include": [
        "./**/*"
    ],
    "exclude": [
        "node_modules"
    ]
}

創(chuàng)建webpack.config.js

$ touch webpack.config.js

./webpack.config.js 中添加:

const webpackConfig = {
    entry: './app/main.tsx',
    output: {
        filename: "bundle.js",
        path: __dirname + "/build",
        publicPatch: __dirname + '/assets/'
    },
    devtool: "source-map",
    devServer:{
        inline: true,
        hot: true,
    },
    resolve: {
        extensions: ["", ".webpack.js", ".web.js", ".ts", ".tsx", ".js"]
    },
    module: {
        loaders: [
            { test: /\.tsx?$/, loader: "awesome-typescript-loader" }
        ],
        preLoaders: [
            { test: /\.js$/, loader: "source-map-loader" }
        ]
    },
    externals: {
        "react": "React",
        "react-dom": "ReactDOM"
    },
}

module.exports =  webpackConfig

修改package.json以webpack-dev-server啟動

設(shè)置-host=0.0.0.0指所有ip都可以訪問, 方便移動端測試開發(fā)

"web": "webpack-dev-server -d --host=0.0.0.0 --port=7000 --hot build/",
    "watch": "webpack --watch"

到現(xiàn)在環(huán)境已經(jīng)搭建好了, 趕快創(chuàng)建一個組件測試一下

添加項目代碼測試

終端創(chuàng)建目錄:

mkdir build app
touch build/index.html app/main.tsx

./build/index.html 中添加:

<!DOCTYPE html>
<html lang='en'>
<head>
    <meta charset='UTF-8'>
    <meta name='viewport' content='width=device-width, initial-scale=1.0, maximum-scale=1, minimum-scale=1, user-scalable=no'>
    <title>Hello typescript</title>
</head>
<body>
    <div id='root'></div>
    <!-- dependencies -->
    <script src='../node_modules/react/dist/react.js'></script>
    <script src='../node_modules/react-dom/dist/react-dom.js'></script>
    <!-- main -->
    <script src='./bundle.js'></script>
</body>
</html>

./app/main.tsx 中添加:

//這里使用react-router對SAP應(yīng)用進行跳轉(zhuǎn)
import * as React from 'react'
import * as ReactDOM from 'react-dom'
import * as ReactRouter from 'react-router'
const { Router, Route, IndexRoute, hashHistory } = ReactRouter

class Test extends React.Component<undefined, undefined> {
    render(){
        return <div>Hello TypeScript</div>
    }
}

ReactDOM.render((
    <Router history={hashHistory}>
        <Route path='/' component={Test}></Route>
    </Router>
), document.getElementById('root'))

啟動項目

  1. 監(jiān)視并且打包TypeScript文件
    • $ webpack --watch
  2. 使用webpak-dev-server運行開發(fā)服務(wù)器
    • $ npm run web
  3. 修改./app/index.tsx中的代碼,刷新頁面試試是否成功

至此, 整個項目已經(jīng)搭建完成了,好好享受TypeScript吧

參考資料

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末型宝,一起剝皮案震驚了整個濱河市絮爷,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌梨树,老刑警劉巖坑夯,帶你破解...
    沈念sama閱讀 219,427評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異柜蜈,居然都是意外死亡,警方通過查閱死者的電腦和手機淑履,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評論 3 395
  • 文/潘曉璐 我一進店門秘噪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人瑰排,你說我怎么就攤上這事贯要〕缟” “怎么了京郑?”我有些...
    開封第一講書人閱讀 165,747評論 0 356
  • 文/不壞的土叔 我叫張陵宅广,是天一觀的道長。 經(jīng)常有香客問我些举,道長跟狱,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,939評論 1 295
  • 正文 為了忘掉前任户魏,我火速辦了婚禮驶臊,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘叼丑。我一直安慰自己关翎,他們只是感情好,可當我...
    茶點故事閱讀 67,955評論 6 392
  • 文/花漫 我一把揭開白布鸠信。 她就那樣靜靜地躺著纵寝,像睡著了一般。 火紅的嫁衣襯著肌膚如雪星立。 梳的紋絲不亂的頭發(fā)上爽茴,一...
    開封第一講書人閱讀 51,737評論 1 305
  • 那天葬凳,我揣著相機與錄音,去河邊找鬼室奏。 笑死沮明,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的窍奋。 我是一名探鬼主播荐健,決...
    沈念sama閱讀 40,448評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼琳袄!你這毒婦竟也來了江场?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,352評論 0 276
  • 序言:老撾萬榮一對情侶失蹤窖逗,失蹤者是張志新(化名)和其女友劉穎址否,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體碎紊,經(jīng)...
    沈念sama閱讀 45,834評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡佑附,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,992評論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了仗考。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片音同。...
    茶點故事閱讀 40,133評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖秃嗜,靈堂內(nèi)的尸體忽然破棺而出权均,到底是詐尸還是另有隱情,我是刑警寧澤锅锨,帶...
    沈念sama閱讀 35,815評論 5 346
  • 正文 年R本政府宣布叽赊,位于F島的核電站,受9級特大地震影響必搞,放射性物質(zhì)發(fā)生泄漏必指。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,477評論 3 331
  • 文/蒙蒙 一恕洲、第九天 我趴在偏房一處隱蔽的房頂上張望塔橡。 院中可真熱鬧,春花似錦研侣、人聲如沸谱邪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,022評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至咆课,卻和暖如春末誓,著一層夾襖步出監(jiān)牢的瞬間扯俱,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,147評論 1 272
  • 我被黑心中介騙來泰國打工喇澡, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留迅栅,地道東北人。 一個月前我還...
    沈念sama閱讀 48,398評論 3 373
  • 正文 我出身青樓晴玖,卻偏偏與公主長得像读存,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子呕屎,可洞房花燭夜當晚...
    茶點故事閱讀 45,077評論 2 355

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