今天继续来更新,本篇文章我们讲环境搭建,主要分享一些环境搭建的学习资源及安装步骤,解决一些安装时可能会出现的问题。
下面就让我们一起进入学习第一步,
搭建TypeScript环境:
一. 环境搭建
1.1. TypeScript环境安装已经配置好的环境,大家可以直接下载:https://github.com/coderwhy/HYLearnTS.git在上一个章节中我们说过,TypeScript最终会被编译成JavaScript代码:
TypeScript运行流程那么我们必然需要对应的编译环境:·首先,TypeScript的环境安装依赖Node,所以需要先保证电脑上有Node和NPM环境;·其次,可以通过NPM来安装TypeScript,之后就可以通过 tsc 来编译TypeScript的代码;首先来进行全局安装:# 安装命令npm install typescript -g # 查看版本tsc --version注意:这里我使用了git

bash的终端,你可以直接使用windows的命令行工具

安装TypeScript1.2. VSCode环境搭建学习或者使用TypeScript有很多编辑器可以供我们选择,目前前端开发比较常用的是两个:·WebStorm:JetBrains 公司的产品,用法和PHPStorm、PyCharm、IDEA用法基本一致;·VSCode:Microsoft 公司的产品,目前可以说已经成为最流行的前端工具,并且本身就是TypeScript编写的;在之前的Flutter文章中我有对比过VSCode和Android Studio的优缺点,其实和VSCode和WebStorm的优缺点对比是相似的,这里不再详细对比。而以后学习和使用TypeScript,我都会优先选择VSCode,所以这里我们主要介绍VSCode的环境搭建。

    1. 下载安装VSCode·下载地址:https://code.visualstudio.com/·下载后直接安装即可
    2. 安装对应的插件·VSCode的另外一个强大的地方就是已经有很多好用的插件了;·我个人针对于前端安装过的插件有:open in browser、 Vetur 、 TSLint 、 Bracket Pair Colorizer等;·这里我不再给出截图,因为我还针对Python、Java、Flutter装过很多的插件,会干扰大家;
      1.3. tsc简单代码测试上面步骤完成后,我们就可以在VSCode中编写我们的TypeScript代码,并且通过一些方法来进行测试。
    3. 打开VSCode,并且新建两个文件:index.tsindex.ts代码如下:// 定义一个变量let message: string = “abc”;message = 123; // 定义一个函数function sum(num1: number, num2: number): number { return num1 + num2;} sum(“abc”, “cba”);我们会发现有两个地方都会报错:错误一:不能将类型“123”分配给类型“string”
    4. 错误一错误二:类型““abc””的参数不能赋给类型“number”的参数
    5. 错误二上面两个错误都是因为我们的代码已经增加了类型约束,不能随便赋值其他类型给我们的变量。将代码修改正确如下:// 定义一个变量let message: string = “abc”;message = “Hello World”; // 定义一个函数function sum(num1: number, num2: number): number { return num1 + num2;} sum(20, 30);2. 将代码编译为JavaScript的代码因为我们说过,代码最终运行在浏览器上,而浏览器是不识别TypeScript代码的,我们需要对他们进行编译:打开VSCode的终端,在其中输入如下命令来编译我们的TypeScript:tsc index.ts查看结果我们会发现,生成了一个index.js文件,并且其中的代码就是普通的JavaScript代码。
    6. 3. JavaScript代码的测试如果我们希望测试这段JavaScript代码就非常简单了,两种方式都可以:·方式一:使用node直接执行JavaScript代码;·方式二:创建一个html文件,在其中引入index.js文件,并且在浏览器中进行测试;这里不再给出具体的步骤,大家可以自行去测试问题:每次都这样测试会不会太麻烦了呢?如果每次我们写完一个TypeScript代码都需要像上面的步骤一样,一点点去完成测试就会过于麻烦,我们可以怎么做呢?·直接配置webpack,让webpack对我们编写的代码进行一个编译,并且自动引入编译后的js文件;·而且webpack可以在代码修改后重新帮助我们进行编译,并且自动刷新浏览器,不需要手动操作;二. 项目环境如果实在不会搭建,可以从我的GitHub上直接下载我已经搭建好的模板:记得点个starGitHub地址:
    7. 2.1. 项目环境的基础配置为了我们之后的学习和使用方便,我们来配置一个webpack的环境:·在环境中我们编写对应的TypeScript代码,让webpack自动帮助我们编译,并且在浏览器中查看结果注意:这里可能需要大家对npm和webpack有一些简单的了解,不会非常复杂(如果完全不懂,按照我给出的步骤来做即可,后续自己进行一些知识的补充)1. 创建一个简单的项目目录结构新建一个新的目录:LearnTypeScript,并且创建如下的目录结构│ index.html├─build│ webpack.config.js└─src main.ts目录和文件夹结构分析:·index.html是跑在浏览器上的模块文件·build文件夹中用于存放webpack的配置信息·src用于存放我们之后编写的所有TypeScript代码2. 使用npm管理项目的依赖webpack本身需要有很多的依赖,并且之后我们也需要启动node服务来快速浏览index.html模板以及编译后的JavaScript代码。我们要使用npm来初始化package.json文件:npm init -y初始化package.json3. 本地依赖TypeScript为什么需要本地依赖TypeScript:·因为我们之后是通过webpack进行编译我们的TypeScript代码的,并不是通过tsc来完成的。(tsc使用的是全局安装的TypeScript依赖)·那么webpack会在本地去查找TypeScript的依赖,所以我们是需要本地依赖TypeScript的;安装本地TypeScript依赖npm install typescript本地安装TypeScript4. 初始化tsconfig.json文件在进行TypeScript开发时,我们会针对TypeScript进行相关的配置,而这些配置信息是存放在一个tsconfig.json文件中的我们并不需要手动去创建它,可以通过命令行直接来生成这样的一个文件:tsc --init初始化tsconfig.json5. 配置tslint来约束代码为了让大家按照严格的TypeScript风格学习代码,这里我希望大家可以加入tslint全局安装tslint:npm install tslint -g在项目中初始化tslint的配置文件:tslint.jsontslint -i初始化tslint.json2.2. 项目环境的Webpack下面我们开始配置webpack相关的内容1. 安装webpack相关的依赖使用webpack开发和打开,需要依赖webpack、webpack-cli、webpack-dev-servernpm install webpack webpack-cli webpack-dev-server -D安装webpack依赖2. 在package.json中添加启动命令为了方便启动webpack,我们在package.json中添加如下启动命令"scripts": { “test”: “echo “Error: no test specified” && exit 1”, “serve”: “cross-env NODE_ENV=development webpack-dev-server --mode=development --config build/webpack.config.js”},自定义启动脚本3. 添加webpack的其他相关依赖依赖一:cross-env这里我们用到一个插件 “cross-env” ,这个插件的作用是可以在webpack.config.js中通过 process.env.NODE_ENV 来获取当前是开发还是生产环境,我们需要这个插件:npm install cross-env -D依赖二:ts-loader因为我们需要解析.ts文件,所以需要依赖对应的loader:ts-loadernpm install ts-loader -D依赖三:html-webpack-plugin编译后的代码需要对应的html模块作为它的运行环境,所以我们需要使用html-webpack-plugin来将它插入到对应的模板中:npm install html-webpack-plugin -D4. 配置webpack.config.js文件将如下配置到webpack.config.js文件中:·这里不再给出详细的说明信息,webpack后面我可能会再开一个专栏来讲解 const HtmlWebpackPlugin = require(“html-webpack-plugin”); module.exports = { entry: “./src/main.ts”, output: { filename: “build.js” }, resolve: { extensions: [".tsx", “.ts”, “.js”] }, module: { rules: [ { test: /.tsx?$/, use: “ts-loader”, exclude: /node_modules/ } ] }, devtool: process.env.NODE_ENV === “production” ? false : “inline-source-map”, devServer: { contentBase: “./dist”, stats: “errors-only”, compress: false, host: “localhost”, port: 8080 }, plugins: [ new HtmlWebpackPlugin({ template: “./index.html” }) ]};2.3. 项目环境下代码测试下面我们就可以愉快的在main.ts中编写代码,之后只需要启动服务即可:测试代码在终端中启动服务:npm run serve程序运行在浏览器中打开:http://localhost:8080/查看结果修改代码,直接可以看到修改后的效果:不需要手动进行任何刷新
      以上就是本次的干货分享,之后除了Flutter也会更新其他技术文章,如:TypeScript、React、Node、数据结构与算法等等,也会陆续做一些自己的从业经验分享。
      好了,本次干货分享到这里就结束啦!感觉意犹未尽?想要获取更多干货及免费的学习资源吗?欢迎加微信:19950277730,关注我,带你进阶成为技术大神!

带你一步一步搭建TypeScript环境的更多相关文章

  1. 【转载】一步一步搭建自己的iOS网络请求库

    一步一步搭建自己的iOS网络请求库(一) 大家好,我是LastDay,很久没有写博客了,这周会分享一个的HTTP请求库的编写经验. 简单的介绍 介绍一下,NSURLSession是iOS7中新的网络接 ...

  2. #使用abp框架与vue一步一步写我是月老的小工具(2) 后台搭建初体验

    #使用abp框架与vue一步一步写我是月老的小工具(2) 后台搭建初体验 一.续上前言 关于这个小玩意的产品思考,假设我暂时把他叫我是月老热心人 这是一个没有中心的关系链,每个人进入以后都是以自己为中 ...

  3. 一步一步使用ABP框架搭建正式项目系列教程之本地化详解

    返回总目录<一步一步使用ABP框架搭建正式项目系列教程> 本篇目录 扯扯本地化 ABP中的本地化 小结 扯扯本地化 本节来说说本地化,也有叫国际化.全球化的,不管怎么个叫法,反正道理都是一 ...

  4. 一步一步了解Cocos2dx 3.0 正式版本开发环境搭建(Win32/Android)

    cocos2d-x 3.0发布有一段时间了,作为一个初学者,我一直觉得cocos2d-x很坑.每个比较大的版本变动,都会有不一样的项目创建方式,每次的跨度都挺大…… 但是凭心而论,3.0RC版本开始 ...

  5. 一步一步教你编写与搭建自动化测试框架——python篇

    [本文出自天外归云的博客园] 这两天用python写了一个自动化测试框架,取名为Auty.准备用来做Web方面的接口测试,以下为Auty框架一步一步的搭建过程——

  6. 一步一步搭建Jenkins环境

    Jenkins使用经验谈1(一步一步搭建Jenkins环境)在公司使用 Jenkins 软件已经有一段时间了,走了很多弯路,但也积累了一些经验,可以和大家分享一下.我们来一起搭建Jenkins环境.首 ...

  7. 一步一步搭建客服系统 (2) 如何搭建SimpleWebRTC信令服务器

    上次介绍了<3分钟实现网页版多人文本.视频聊天室 (含完整源码)>使用的是default 信令服务器,只是为了方便快速开始而已.SimapleWebRTC官方文档里第一条就讲到,不要在生产 ...

  8. [ALM]一步一步搭建MS ALM环境 - 安装TFS + SQL SERVER

    描述: 安装SQL SERVER 2012,安装TFS 2013,配置TFS,挽起袖子,准备干活儿 步骤: 1,打开Hyper-V Manager,参考[Hyper-V]使用操作系统模板创建新的虚拟机 ...

  9. ubuntu16.04下Hyperledger之搭建Fabric环境简单操作(五步启动e2e_cli)

    如果你已经安装好go等工具.git及checkout相关代及下载相关镜像,您只需下面5步就能up e2e_cli~/go/src/github.com/hyperledger/fabric$ sudo ...

随机推荐

  1. 最长升序列 DP

    class Solution: def lengthOfLIS(self,nums): if not nums:return 0 #边界处理 dp = [1 for _ in range(len(nu ...

  2. 为 Raft 引入 leader lease 机制解决集群脑裂时的 stale read 问题

    问题:当 raft group 发生脑裂的情况下,老的 raft leader 可能在一段时间内并不知道新的 leader 已经被选举出来,这时候客户端在老的 leader 上可能会读取出陈旧的数据( ...

  3. Firefox disable search in the address bar

    disable search in the address bar Hi oitconz, setting keyword.enabled to false prevents Firefox from ...

  4. Kubernetes 下零信任安全架构分析

    点击下载<不一样的 双11 技术:阿里巴巴经济体云原生实践> 本文节选自<不一样的 双11 技术:阿里巴巴经济体云原生实践>一书,点击上方图片即可下载! 作者 杨宁(麟童) 阿 ...

  5. 【转】Android检查手机是否被root

    目前来说Android平台并没有提供能够root检查的工具.但是我们可以通过两种方式来判断 手机里面是否有su文件 这个su文件是不是能够执行 但是这两种检查方式都存在缺点. 第一种存在误测和漏测的情 ...

  6. JVM 类加载器命名空间深度解析与实例分析

    一.创建Sample 1.创建实例 public class MyPerson { private MyPerson myPerson; public void setMyPerson(Object ...

  7. Jira 入门【转】

    JIRA是Atlassian公司出品的项目与事务跟踪工具,被广泛应用于缺陷跟踪.客户服务.需求收集.流程审批.任务跟踪.项目跟踪和敏捷管理等工作领域.它是一个集 项目计划.任务分配.需求管理.错误跟踪 ...

  8. Oracle 查询表分区相关信息

    Oracle 查询表分区相关信息 --表分区 --1,分区表信息 -- (1)显示数据库所有分区表的信息 select * from DBA_PART_TABLES a where a.owner=u ...

  9. 页面的Tab选项卡 简单实例

    <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="C ...

  10. supervisord守护进程的使用

    原文链接:http://blog.csdn.net/xyang81/article/details/51555473 Supervisor(http://supervisord.org/)是用Pyth ...