首页 > web前端 > js教程 > 正文

分享TypeScript的一些小技巧

零下一度
发布: 2018-05-17 14:16:21
原创
2780人浏览过

在c++项目中编译typescript(以下简称ts)

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

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

    --outFile是输出参数,后面紧跟输出位置。

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

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

  输出写$(FileName).js,这个应该是判断编译必要性的。

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

在ts中引用jquery的声明

  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,这样不是很方便。

巧文书
巧文书

巧文书是一款AI写标书、AI写方案的产品。通过自研的先进AI大模型,精准解析招标文件,智能生成投标内容。

巧文书 61
查看详情 巧文书

  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的一些小技巧的详细内容,更多请关注php中文网其它相关文章!

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号