TypeScript和JavaScript的一些小技巧记录
项目里使用到的技巧,记录一下,会持续更新。
JS的技巧完全可以使用到TS上哦。
JS
向下取整
Math.floor(4.5); //
简写:
var num = 4.5;
~~num;
num << 0;
num >> 0;
num >>> 0;
四种写法都会返回向下取整后的值,即4。
但是要注意,简写的方式用在负数上会得到错误的结果:
Math.floor(-4.1); // -5
~~-4.1; // -4
-4.1 << 0; // -4
-4.1 >> 0; // -4
-4.1 >>> 0; //
或者说在负数上变成了向上取整,另外由于 >>> 是无符号的位移操作,所以会得到一个巨大的正数。另外一点:没有 <<< 这个操作符哦。
字符串转数字
parseInt("4.5"); //
parseFloat("4.5"); // 4.5
parseInt({a:1}); // NaN
简写:
var num = "4.5";
+num; // 4.5 num = {a:1};
+num; // NaN
转Boolean值
Boolean(5.99); // true
Boolean(0); // false
Boolean(1); // true
Boolean(null); // false
Boolean(undefined); // false
Boolean(""); // false
Boolean("1"); // true
Boolean({}); // true
简写:
!!5.99; // true
!!0; // false
!!1; // true
!!null; // false
!!undefined; // false
!!""; // false
!!"1"; // true
!!{}; // true
void 0
如果编写的代码会直接发布,尽可能用 void 0 代替 null 和 undefined,因为在某些浏览器中,undefined可以被赋值导致判断全部错误。
比如在TS中,编译后,使用到的undefined都会替换为 void 0。
TS
多使用接口方式
比如传递参数时,这么写:
func(a: Point);
只能接受Point类型的变量,如果用下面的写法:
func(a: {x:number, y:number});
就可以接受带有x和y的所有变量,可以更好的复用该函数。
快速得到属性
一般的写法:
let x = point.x;
let y = point.y;
简写:
let {x, y} = point;
一般的写法:
let arr = "100;200;300".split(';');
let a = arr[0];
let b = arr[1];
let c = arr[2];
简写:
let [a, b, c] = "100;200;300".split(';');
快速写入属性
一般的写法:
let a = 0;
let b = "heelo";
let obj = {a: a, b: b};
简写:
let a = 0;
let b = "heelo";
let obj = {a, b};
参数类类型控制
比如我们需要传递一个参数,该参数是MyClass类的类型,而不是实例时,一般只能用any,实际上是可以指定类型的,写法如下:
public func(classType: { new(): MyClass }): void;
传入类型,得到该类型的实例
一般用于工厂或对象池等:
export function getInstance<T>(Class: {new () : T}): T {
return new Class();
}
单例的简写方式
static get instance(): Obj {
return this._instance || (this._instance = new Obj());
}
类属性控制
interface IObj {
// 可选属性
name?: string;
// 只读属性
readonly age: number;
}
控制动态属性:
interface Map<T> {
[key: string]: T;
}
用接口来规范一个对象
比如我们有一个接口,可以用下面的方法来规范一个对象,而不用编写一个实现该接口的类:
export interface IPoint {
x: number;
y: number;
}
export function foo(point: IPoint) {
// ...
}
foo(<IPoint> {x: 100, y: 100});
如果打错属性名称或缺少必须的属性会报错,属性类型不匹配也会报错,可以大大降低写错的问题。另外添加额外属性是允许的。
TypeScript和JavaScript的一些小技巧记录的更多相关文章
- ( 译、持续更新 ) JavaScript 上分小技巧(三)
最近家里杂事较多,自学时间实在少的可怜,所以都在空闲时间看看老外写的内容,学习之外顺便翻译分享~等学习的时间充足些再写写自己的一些学习内容和知识点分析(最近有在接触的:复习(C#,SQL).(学习)T ...
- ( 译、持续更新 ) JavaScript 上分小技巧(四)
后续如有内容,本篇将会照常更新并排满15个知识点,以下是其他几篇译文的地址: 第一篇地址:( 译.持续更新 ) JavaScript 上分小技巧(一) 第二篇地址:( 译.持续更新 ) JavaScr ...
- ( 译、持续更新 ) JavaScript 上分小技巧(二)
考虑到文章过长,不便于阅读,这里分出第二篇,如有后续,每15个知识点分为一篇... 第一篇地址:( 译.持续更新 ) JavaScript 上分小技巧(一) 第三篇地址:( 译.持续更新 ) Java ...
- ( 译、持续更新 ) JavaScript 上分小技巧(一)
感谢好友破狼提供的这篇好文章,也感谢写这些知识点的作者们和将他们整理到一起的作者.这是github上的一篇文章,在这里本兽也就只做翻译,由于本兽英语水平和编程能力都不咋地,如有不好的地方也请多理解体谅 ...
- 19个JavaScript简化编码小技巧
这篇文章适合任何一位基于JavaScript开发的开发者.我写这篇文章主要涉及JavaScript中一些简写的代码,帮助大家更好理解一些JavaScript的基础.希望这些代码能从不同的角度帮助你更好 ...
- Javascript字符串拼接小技巧
在Javascript中经常会遇到字符串的问题,但是如果要拼接的字符串过长就比较麻烦了. 如果是在一行的,可读性差不说,如果要换行的,会直接报错. 在此介绍几种Javascript拼接字符串的技巧. ...
- docker的小技巧记录(如果使用了更多会继续添加)
docker小技巧 复制本地sql脚本到docker容器mysql中进行使用 # 找到容器 docker ps # 复制文件 cp ./xxx.sql container-id:/tmp/ # 进入容 ...
- JavaScript的一些小技巧(转)
本文是一篇翻译文章,原文信息如下: 原文:45 Useful JavaScript Tips, Tricks and Best Practices 作者:Saad Mousliki JavaScrip ...
- js_开发小技巧记录(一)
(一) 生成从minNum到maxNum的随机数 <!DOCTYPE html> <html> <head> <meta charset="UTF- ...
随机推荐
- Java-从Double类型精度丢失认识BigDecimal
Java-从Double类型精度丢失认识BigDecimal 参考资料 https://www.jianshu.com/p/07e3eeb90f18 https://zh.wikipedia.org/ ...
- 2018-7-17-随笔-params和ref、out用法、事件访问器
**************************************************************************************************** ...
- [Web]flask-excel实现excel文件下载的前后端实现
之前同事写了前端表格导出的功能, 前后端逻辑没有梳理, 导致后端代码十分臃肿. 接手之后, 重新选择了前端table插件, 从jqxGrid变更为bootstrapTable. 本来想依赖集成的tab ...
- CODEVS.5037.线段树练习4加强版(分块 区间k的倍数)
题目链接 /* 如果用线段树,每个节点要再开k的空间,显然不行.但是分块可以(虽然空间依旧爆炸) 分块.用bloans[i][j]表示 第i块 模k为j 的有多少个 对于不是整块的,查询时应判断 A[ ...
- VirtWire 注册教程
1 首先打开virtwire官方网站 网站地址:戳我 2 如果现实如下图所示,点击红色框中的网址连接.(网页中有Terms of Service可以读) 3 如果网页正常打开,点击“ORDERHOST ...
- Django——photo
要点: models 图片类型文件要使用models.ImageField(upload='文件夹名') 普通文件使用FileField 时间类型使用DatetimeField(auto_now_ad ...
- bzoj1051: [HAOI2006]受欢迎的牛(tarjan板子)
1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 6064 Solved: 3179[Submit][Sta ...
- 超详细 Spring @RequestMapping 注解使用技巧
@RequestMapping 是 Spring Web 应用程序中最常被用到的注解之一.这个注解会将 HTTP 请求映射到 MVC 和 REST 控制器的处理方法上. 在这篇文章中,你将会看到 @R ...
- Django中提供的6种缓存方式
由于Django是动态网站,所有每次请求均会去数据进行相应的操作,当程序访问量大时,耗时必然会更加明显,最简单解决方式是使用: 缓存,缓存将一个某个views的返回值保存至内存或者memcache中, ...
- 【数论&想法题】小C的问题 @"科林明伦杯"哈尔滨理工大学第八届程序设计竞赛
Time Limit: 1000 MS Memory Limit: 256000 K Description 小C是一个可爱的女孩,她特别喜欢世界上最稳定的图形:三角形.有一天她得到了n根木棍,她把这 ...