JHipster一知半解- 4.1 语言框架Typescript和Angular

回文集目录:JHipster一知半解

Angular


概述

近几年,随着微服务、前后端分离的理念逐步深入人心;作为页面控制的核心语言(javasprit)也引来了最辉煌的时刻。一方面,进行语言自身特性扩展(ES5、ES6、Typescript),逐步增强原始版本中过于随意,作用域难以控制等缺陷,另一方面,进行框架化设计,出现了React、Angular、Vue几个流行的框架。
JHipster非常适合后端程序员转型而作,它之前选择的是AngularJs,之后也同步跟上Angular(感觉后端气质,依赖注入,模块划分、装饰器等)。

Typesript

看官网即可,JS语法超集,当做手册翻

tslint.json

定义:TSLint is an extensible static analysis tool that checks TypeScript code for readability, maintainability, and functionality errors。
也就是说,它是一个静态的代码分析工具,用来检查TypeScript编写是否符合规范,用来提高可读性,可维护性

要从jshint说起了,毕竟js是一个毕竟是宽松的语言,好处是写起来快,坏处是改起来苦。然而这个世界并没有一次写完,就很完备,永远不会修改的代码。于是出现了jshint,告诉代码分析工具(主要是编辑器,如Webstorm,Vs code等),需要帮我检查我写的js,如果有什么不规范的地方给我标出来,保证我写的代码质量高。
到了Typescript这,由于有向下兼容的特性,随便写还是可能的,但是这样就失去了Typescript良好的封装性。于是也顺理成章出来tslint,用来检查.ts文件。
那么具体按照什么标准检查呢,就需要tslint.json作为说明书,传达我们需要检测的规则标准。
tslint.json里面主要就是rulesDirectory和rules两块,具体可自行查看,这里就不在赘述了。(教科书般的配置,可直接copy到任何工程)

tsconfig.json 和 tsconfig-aot.json

本质上ts文件是需要编译成js才能真正在浏览器上运行的,这两个是Typescript编译器的配置文件,指定了用来编译这个项目的根文件和编译选项,告诉tsc命令怎么编译ts。
通过对比可以看出,aot(生产环境)编译的LIB就是ES5,当前浏览器都支持的语言,而普通版本就更为高版本一些,而且还同步生成sourcemap,便于进行开发调试。
值得注意的是,这两个也是可以复用到其他项目的,需要根据自己项目组织情况,修改inclue和exclude目录位置
(详细说明在Type官网的tsconfig.json节)

Angular-cli

ng help查看,ng工程的创建,构建,编译,测试,运行全生命周期管理。当然我们用jhipster,它已经封装了一部分功能了。

.angular-cli.json

由angular-cli记录的配置信息,运行ng命令会先读取其中配置,例如ng test就会读取其中“test”节。既然是加.在开头的,理论上就不是给开发者编辑的(当然事实并非如此)。不过jhipster前端本身并不是严格的ng工程,script里面也没有
使用ng命令的地方,这个文件可以忽略。。

现在,Angular现在教程挺多的,看书,看官网

资源和书籍推荐

强烈推荐区

  • TypeScript官网
    https://www.tslang.cn/

  • angular官网
    https://angular.cn/

  • Angular权威教程
    https://item.jd.com/12176534.html
    https://pan.baidu.com/s/1eSbCURK 密码:ans1

  • Angular 4.x 修仙之路
    https://segmentfault.com/a/1190000008754631

  • Angular2 从0到1 (一)
    https://item.jd.com/12059091.html
    http://www.jianshu.com/p/9af9f203e0b1

参考区

  • tslint 官网
    https://palantir.github.io/tslint/

  • Learning Typescript-读书笔记
    https://www.jianshu.com/u/a76565e2af90

你可能感兴趣的:(JHipster一知半解- 4.1 语言框架Typescript和Angular)