大橙子网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要为大家展示了“ThinkJS2.1支持TypeScript的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“ThinkJS2.1支持TypeScript的示例分析”这篇文章吧。
在阳谷等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供网站设计、成都网站设计 网站设计制作按需设计,公司网站建设,企业网站建设,品牌网站建设,营销型网站,成都外贸网站建设公司,阳谷网站建设费用合理。
一:支持TypeScript
TypeScript 是一种由微软开发的自由和开源的编程语言。它是 JavaScript 的一个超集,向这个语言添加了可选的静态类型,在大型项目里非常有用。ThinkJS 2.1 开始支持了创建 TypeScript 类型的项目,并且开发时会自动编译、自动更新,无需手工编译等复杂的操作。细则如下:
1、创建 TypeScript 项目
2、.d.ts 文件
3、已有项目升级为 TypeScript 项目
修改入口文件
修改 package.json
修改 .thinkjsrc
下载 think.d.ts 描述文件
修改文件后缀
项目文件里添加描述文件
二:性能提升
评价一个框架是否出色,一方面看支持的功能,另一方面也要看性能。虽然 ThinkJS 更适合大型项目,功能和复杂度远远超过 Express 和 Koa,但性能上并不比 Express 和 Koa 逊色多少,具体的测试数据请见下图。
注:以上数据使用分布式压力测试系统测试。
从上图中测试数据可以看到,虽然 ThinkJS 比 Express 和 Koa 性能要差一些,但差别并不大。ThinkJS 和 Sails.js 都更符合大型项目,但 ThinkJS 的性能要比 Sails.js 高很多。
具体测试代码请见:https://github.com/thinkjs-team/thinkjs-performance-test,可以下载代码在本机测试,如果使用 ab 测试工具,请注意该工具在 Mac 系统下很不稳定,多次测试结果会相差很大。
三:更多特性
ThinkJS 2.1版本除了上述两个较为突出的特性以外,更多特性如下:
Controller 支持子目录的形式
支持 PostgreSQL 数据库
Model schema 支持默认值
Hook 里的 middleware 返回 null 可以阻止后续的 middleware 执行
http 和 controller 添加 display 的别名方法 render
添加串行执行方法 think.waterfall
Validate 支持正则
fetch 支持传数据
Logic 支持判断请求类型
定时任务里支持直接调用 action
Babel 升级到 6
国际化语言对大小写不再敏感
将获取模板文件内容改为异步
http 对象不在继承自 EventEmitter 类
去除 think.mode_mini 模式,controller 支持子目录
数据库配置 name 改为 database
修改现在的 fields 为 schema
数据库配置 pwd 改为 password
优化 http 对象生成方式,不用每次都复制
过滤 .svn, .git 等隐藏类型的文件
将文件 bin/index.js 移动为 src/command.js
runtime 目录移动到项目根目录下,添加 think.RUNTIME_PATH 路径常量
adapter type 增加自动转为小写的功能,并给出提示
增加 thinkData,用于缓存系统常用数据
合并 think.locale 和 controller.locale 方法
修复 nunjucks 模板继承文件找不到的问题
修复 pathname 里含有转义的 / 导致识别错误的问题
修复 http.file 方法返回的数据遭到修改导致源数据也修改的问题
修复路径中 / 在 windows 下需要替换为 \\ 的问题
修复 nunjucks 下模板文件在不在根目录导致报错的问题
修复 production 环境下,页面上可能输出敏感数据的问题
修复 development 模式下,JSON 数据解析失败后没有报错信息不好定位的问题
修复 view root_path 修改后,创建模块时视图路径没更新的问题
修复 required|int 规则校验不正确的问题
修复 redis cache 解析配置的问题
修复 REST API 不支持 logic 的问题
修复 count 方法如果传入字段名是关键字会出错的问题
以上是“ThinkJS2.1支持TypeScript的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!