在C++项目中编译TypeScript(以下简称ts)

  编辑ts文件的属性,项类型选择“自定义生产工具”。

  命令行输入tsc所在位置与编译参数,我的是"C:\Program Files (x86)\Microsoft SDKs\TypeScript\2.2\tsc" %(Identity) --out %(RelativeDir)/%(FileName).js -t es5。有空格的UNC(通用命名惯例)需要用双引号引起来。%(Identity)是被编译文件位置。

    --out是输出参数,后面紧跟输出位置。可以忽略此参数,那么输出的文件名只是简单的修改ts扩展名为js。

    -t(--target)是目标类型,我用ES5,还可以是"ES3" (default), "ES5", "ES6"/"ES2015", "ES2016", "ES2017" or "ESNext"。

  说明写%(Identity)就可以,这个随意。

  输出写%(RelativeDir)/%(FileName).js,用于比较编译事件,判断编译必要性。

ps:这是我研究的方法,我感觉还有更标准的。官方并没有介绍如何在c++项目中怎么编译。

在ts中引用jquery的声明

  【仅适用于VS开发环境,不适合VSCode及其他IDE】jquery并没有使用ts编写,所以git上也找不到ts文件,好在vs对jquery提供了强大的支持,任意项目类型新建html文件,包含任意版本jquery的js文件,那么你的智能提示就自动支持$了。接下来鼠标定位在$左或右按F12查看定义就会自动转到index.d.ts文件,右键标签选打开所在目录,就能找到这个文件,复制到自己的项目目录。

  用三斜杠语法引用到当前ts文件/// <reference path="jquery.d.ts"/>

  .d.ts文件是声明文件,并不含有逻辑代码,只是结构而已。

如何为自己的ts文件生成声明文件

  同前,tsc编译程序可以生成声明文件,只需要参数-d/--declaration 及ts文件即可。

  例如:tsc -d main.ts

用命令行编译ts文件?

  可以,只要你不嫌麻烦。VS的开发者命令提示符(Developer Command Prompt for VS 2017)可以直接使用tsc命令。你可以把它固定到“开始”屏幕,提高开启效率。

拿不到声明如何解决

  

  declare var swal: (arg: any) => any;

  加入你有swal这样一个函数并没有提供ts声明,这样就可以自由使用了。当然,这是一个参数的掉用。

  ts里HTMLElement.remove这个成员是不存在的,只能用它父对象的removeChild,这样不是很方便。

  dom:HTMLElement;

  (<any>dom).remove();// 就这样勉强的转为any再调用remove吧。

不用为每个对象都建立一个类

  ts的class不支持内部声明class。所以成员的类型声明在class外面也不太合适。

  class foo{
    member:{mem1:number, mem2?:string};// 加问号表示可有可无
  }

  这样member就类似一个内部类了。

事件的订阅及this参数

  class bar{
    sub(){
      dom.onclick=function(){this};
    }
  }

  这样function函数里的this是dom对象。

  dom.onclick=()=>{this};

  这个this表示的是类bar的实例。

  那么我想又要有dom这个对象,又要有bar的实例呢?

  我目前只能用闭包了:

  class bar{
    click(node:HTMLElement, ev:MouseEvent){
      this...
    }
    dom.onclick = (ev:MouseEvent)=>this.click(dom,ev);
  }

  dom用闭包传进去,this还是你期待的this,毕竟click是bar的成员函数。

只读属性不用readonly

  如果你想修改,readonly对类内部访问不太方便

  所以应该用Object.defineProperty,ts有更方便的set/get操作属性。

  class baz{
    _attr:[];
    get attr(){
      return _attr;
    }
  }

  这样attr就只能读取了。要使用属性特性,需要将ts编译器的目标选项(-t/--target)设置到es5或以上。

本文章会持续更新,只要是ts的相关技巧我都会更新,如果你也关注typescript技术,请关注我/收藏此文章。

btw:cnblogs不支持ts代码着色,用的JS代码着色。

TypeScript技巧集锦(陆续更新)的更多相关文章

  1. 【Android面试】Android面试题集锦 (陆续更新)(最新2012-6-18) eoe上看到的

    ===============eoeAndroid社区推荐:======================= 1.Android开发新浪面试题[开发者必看哦]下载地址 http://www.eoeand ...

  2. 最有用的Linux命令行使用技巧集锦

    最近在Quora上看到一个问答题目,关于在高效率Linux用户节省时间Tips.将该题目的回答进行学习总结,加上自己的一些经验,记录如下,方便自己和大家参考. 下面介绍的都是一些命令行工具,这些工具在 ...

  3. [视频]MAC OS 技巧之如何更新及重装MAC系统

    mac os是当今最好用的桌面操作系统,但再好的系统也有新版本发布的一天,或者被极客的你尝试各种设置而配置混乱了,这时我们就要进行系统更新或者重装了. 系统更新 Mac OS有新版本推出时,会自动在A ...

  4. Cocos2d-x 3.0final手机游戏开发视频教程2014 - 自学编程 -(陆续更新中)

    内容: 非常多人问我:沈老师,要不要更新引擎版本号到3.0,更新这么快,以后会不会每一个月都有一次,好怕呀. 我说:无论你曾经是哪个版本号,3.0final是一个架构级别的升级,能够在新项目中果断升级 ...

  5. python3.4学习笔记(六) 常用快捷键使用技巧,持续更新

    python3.4学习笔记(六) 常用快捷键使用技巧,持续更新 安装IDLE后鼠标右键点击*.py 文件,可以看到Edit with IDLE 选择这个可以直接打开编辑器.IDLE默认不能显示行号,使 ...

  6. Unity 游戏开发技巧集锦之使用cookie类型的纹理模拟云层的移动

    Unity 游戏开发技巧集锦之使用cookie类型的纹理模拟云层的移动 使用cookie类型的纹理模拟云层的移动 现实生活中,当阳光直射大地,而天空中又有很多云时,云层的影子总是会投射在大地上,风吹着 ...

  7. Unity 游戏开发技巧集锦之创建透明的材质

    Unity 游戏开发技巧集锦之创建透明的材质 Unity创建透明的材质 生活中不乏透明或者半透明的事物.例如,擦的十分干净的玻璃,看起来就是透明的:一些塑料卡片,看起来就是半透明的,如图3-23所示. ...

  8. Unity 游戏开发技巧集锦之创建部分光滑部分粗糙的材质

    Unity 游戏开发技巧集锦之创建部分光滑部分粗糙的材质 创建部分光滑部分粗糙的材质 生活中,有类物体的表面既有光滑的部分,又有粗糙的部分,例如丽江的石板路,如图3-17所示,石板的表面本来是粗糙的, ...

  9. Unity 游戏开发技巧集锦之材质的应用的创建反射材质

    Unity 游戏开发技巧集锦之材质的应用的创建反射材质 Unity中材质的应用 游戏中,大多数材质的应用都离不开纹理,而纹理本身是图片.所以,在学习本章时,最好在电脑上安装一个可以编辑图片的功能强大的 ...

随机推荐

  1. IT行业能力细分

    在软件行业工作7年了,平时很懒,懒得做分享,今天特意分享一下软件行业,职业大的技术分类,同学们可根据自己职业规划补充学习知识块.

  2. APP反编译第一课《如何找到核心代码》

    相信很多人都应该会去接触APP反编译,本小七给大家带来入门级别套路,自己也在慢慢摸索学习,一起成长吧.第一步,反编译需要的工具有:一.java环境,其实这里你只要安装了burp就不用管这个的二.apk ...

  3. scp 命令快速使用讲解

    在 Linux 下使用 scp 命令 scp 是安全拷贝协议(Secure Copy Protocol)的缩写,和众多 Linux/Unix 使用者所熟知的拷贝(cp)命令一样.scp 的使用方式类似 ...

  4. NancyFx 2.0的开源框架的使用-Basic

    这是NancyFx开源框架中的Basic认证,学习一下! 首先当然是新建一个空的Web,BasicDemo 继续在项目中添加Nuget包,记得安装的Nuget包是最新的预发行版 Nancy Nancy ...

  5. hammer的初始化及移动端各种滑动

    前言:本人对hammer了解不是很多,早做项目时遇到了手机端的一些滑动事件,特此分析下hammer的某些属性. hammer.js是一款开源的移动端脚本框架,他可以完美的实现在移端开发的大多数事件,如 ...

  6. redis中的事务

    首先明白在java中线程和进程的区别: 1.什么是多线程? 是指一个应用程序同时执行多个任务,一般来说一个任务就是一个线程 ,而一个应用程序有一个以上的线程我们称之为多线程. 2.什么是进程? 进程是 ...

  7. [刷题]算法竞赛入门经典(第2版) 4-3/UVa220 - Othello

    书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 代码:(Accepted,0 ms) //UVa 220 - Othello #include<iostream ...

  8. 增强for循环 -- foreach循环

    1  作用 简化迭代器的书写格式.(注意:foreach循环的底层还是使用了迭代器遍历.) 2  适用范围 如果是实现了Iterable接口的对象或者是数组对象都可以使用foreach循环. 3  格 ...

  9. 门面(Facade)模式

    门面模式是对象的结构模式,外部与一个子系统的通信必须通过一个统一的门面对象进行.门面模式提供一个高层次的接口,使得子系统更易于使用. 医院的例子 现代的软件系统都是比较复杂的,设计师处理复杂系统的一个 ...

  10. angular.js封装的树形指令

    html ul.tree-show sub-transclude-set ng-transclude li.parent(ng-repeat='(key,item) in treeData',ng-i ...