typescript基础语法--变量/函数/指令/类
博客地址 :https://www.cnblogs.com/sandraryan/
要把ts文件引入到html中,首先要转码为js文件。
步骤:
终端运行: npm i -g typescript
tsc --init
然后再vscode中ctrl shift b, 点击watch

以后保存ts文件,js文件自动刷新
如果你觉得这个方法太简单 你可以选择写一行代码在终端重新编译一次,指令是: tsc ts文件名,进行编译
然后看看基本语法叭
声明变量:
先搞一个html文件吧转码后的js文件引进去,然后我们操作ts文件(你懂我意思吧)
这个是ts文件命名为ts1.ts
声明变量很简单,都写在注释里了~~~~
总之就是:
ts变量的声明
1.ts在声明变量时,要规定变量的类型,
2.如没有规定,会在第一次为变量赋值时确定它的类型
3.一旦一个变量的类型被确定,那么之后使用这个变量时,不能改变变量类型(会报错)
let a = 100;
console.log(1);
/**
* ts变量的声明
* 1.ts在声明变量时,要规定变量的类型,
* 2.如没有规定,会在第一次为变量赋值时确定它的类型
* 3.一旦一个变量的类型被确定,那么之后使用这个变量时,只能依托这个类型
*/
// a = 'ji';
// 声明变量时约束类型
let bol:boolean = true;
// bol = 2333;
// 声明数组list,数组中所有类型都是字符串
let list:string[] = ['hi','guys','how','do','you','do'];
console.log(list);
// 声明数组另一种方法
let arr:Array<string> = ['hi','guys','how','do','you','do'];
console.log(arr);
// 元组: 声明时规定每个元素类型,规定元素个数,即一个固定长度的类型不同的数组
let t:[boolean,string,number] = [false,'hi',233];
// 不能push 不能修改
// 声明枚举类型
//将所有的可能性一一列举在某个数据中,需要取值时可以用index,获取index可以用数据获取
//下标从0开始 也可手动设置下标设置好后,下标从该设置往后延续10 11 ...
enum Color {
//要枚举出来的数据本身
yellow,red,green,blue
}
console.log(Color);
console.log(Color['yellow']);
console.log(Color[1]);
// 声明一个any的数据类型
let an:any = 90;
an = 'hello';
an = [2,3,4];
console.log(an); // void类型的数据只能复制为null或者undefined
let v:void;
console.log(v);
这个是转码后的js文件
"use strict";
var a = 100;
console.log(1);
/**
* ts变量的声明
* 1.ts在声明变量时,要规定变量的类型,
* 2.如没有规定,会在第一次为变量赋值时确定它的类型
* 3.一旦一个变量的类型被确定,那么之后使用这个变量时,只能依托这个类型
*/
// a = 'ji';
// 声明变量时约束类型
var bol = true;
// bol = 2333;
// 声明数组list,数组中所有类型都是字符串
var list = ['hi', 'guys', 'how', 'do', 'you', 'do'];
console.log(list);
// 声明数组另一种方法
var arr = ['hi', 'guys', 'how', 'do', 'you', 'do'];
console.log(arr);
// 元组: 声明时规定每个元素类型,规定元素个数,即一个固定长度的类型不同的数组
var t = [false, 'hi', 233];
// 不能push 不能修改
// 声明枚举类型
//将所有的可能性一一列举在某个数据中,需要取值时可以用index,获取index可以用数据获取
//下标从0开始 也可手动设置下标设置好后,下标从该设置往后延续10 11 ...
var Color;
(function (Color) {
//要枚举出来的数据本身
Color[Color["yellow"] = 0] = "yellow";
Color[Color["red"] = 1] = "red";
Color[Color["green"] = 2] = "green";
Color[Color["blue"] = 3] = "blue";
})(Color || (Color = {}));
console.log(Color);
console.log(Color['yellow']);
console.log(Color[1]);
// 声明一个any的数据类型
var an = 90;
an = 'hello';
an = [2, 3, 4];
console.log(an);
// void类型的数据只能复制为null或者undefined
var v;
console.log(v);
引入html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<script src="ts1.js"></script>
</body>
</html>
函数
ts中函数也很简单~ 举个例子
ts函数可以指定参数和返回值的类型,也可以添加默认值(在声明函数添加形参的时候)
// 函数
function fn(x:number,y:number):number{
return x+y;
}
let r:number = fn(3,4);
console.log(r); //
// 声明函数时规定函数参数类型和返回值的类型,函数调用时必须严格遵循这个规定,否则编码报错
// 为参数设置默认值,拥有默认值的参数应该声明在参数列表最后面
function fn2(x:number=10,y:number=20):number{
return x+y;
}
let r2 = fn2();
console.log(r2);
// 函数的剩余参数
// an是除了num之外的所有参数列表,成为剩余参数,类型规定为string,是个数组
function fn3(num:number,...an:string[]){
console.log(num);
console.log(an);
}
fn3(45,'a','b','c');
// 剩余参数也可以是个元组,规定类型
function fn4(num:number,...an:[string,boolean]){
console.log(num);
console.log(an);
}
fn4(45,'r',true);
转码后的js文件
"use strict";
// 函数
function fn(x, y) {
return x + y;
}
var r = fn(3, 4);
console.log(r); //
// 声明函数时规定函数参数类型和返回值的类型,函数调用时必须严格遵循这个规定,否则编码报错
// 为参数设置默认值,拥有默认值的参数应该声明在参数列表最后面
function fn2(x, y) {
if (x === void 0) { x = 10; }
if (y === void 0) { y = 20; }
return x + y;
}
var r2 = fn2();
console.log(r2);
// 函数的剩余参数
// an是除了num之外的所有参数列表,成为剩余参数,类型规定为string,是个数组/
function fn3(num) {
var an = [];
for (var _i = 1; _i < arguments.length; _i++) {
an[_i - 1] = arguments[_i];
}
console.log(num);
console.log(an);
}
fn3(45, 'a', 'b', 'c');
// 剩余参数也可以是个元组,规定类型
function fn4(num) {
var an = [];
for (var _i = 1; _i < arguments.length; _i++) {
an[_i - 1] = arguments[_i];
}
console.log(num);
console.log(an);
}
fn4(45, 'r', true);
类的声明
ts文件:
js文件:
抽象类
ts:
// 抽象类
abstract class People{
// 声明属性
readonly eyes:number = 2;
// 声明类的一个普通方法
public eat(){
console.log('i can eat');
}
//声明类的抽象方法,抽象方法不能有方法体,只能约束参数和返回值的类型
abstract run();
abstract sum(x:number,y:number):number; }
// 抽象类里不能实例化对象,因为抽象类中包含了抽象方法,抽象方法没有方法体,如果允许从抽象类中实例化对象,后面的逻辑都不成立
//let p = new People(); //报错:无法创建抽象类的实例。
js
"use strict";
// 抽象类
var People = /** @class */ (function () {
function People() {
// 声明属性
this.eyes = 2;
}
// 声明类的一个普通方法
People.prototype.eat = function () {
console.log('i can eat');
};
return People;
}());
typescript基础语法--变量/函数/指令/类的更多相关文章
- JAVA基础语法:函数(方法)、类和对象(转载)
4.JAVA基础语法:函数(方法).类和对象 函数 在java中函数也称为方法,是一段具备某种功能的可重用代码块. 一个函数包括这几部分: 函数头 函数头包括函数访问修饰符,函数返回值类型, 函数名, ...
- openresty开发系列14--lua基础语法3函数
openresty开发系列14--lua基础语法3函数 一)function (函数) 有名函数: optional_function_scope function function_name( ar ...
- python学习第五讲,python基础语法之函数语法,与Import导入模块.
目录 python学习第五讲,python基础语法之函数语法,与Import导入模块. 一丶函数简介 1.函数语法定义 2.函数的调用 3.函数的文档注释 4.函数的参数 5.函数的形参跟实参 6.函 ...
- flutter--Dart基础语法(三)类和对象、泛型、库
一.前言 Flutter 是 Google 开源的 UI 工具包,帮助开发者通过一套代码库高效构建多平台精美应用,Flutter 开源.免费,拥有宽松的开源协议,支持移动.Web.桌面和嵌入式平台. ...
- python基础语法_9-0函数概念
http://www.runoob.com/python3/python3-function.html 函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数能提高应用的模块性,和代 ...
- go基础语法-变量定义
1.基础定义 变量类型在变量名后 var a int var s string 2.定义并赋值 var a,b int = 1,2 var s string="abc" 3.类型推 ...
- java基础(环境设置,基础语法,函数数组)
框架图 环境搭建 课程中常见dos命令: dir : 列出当前目录下的文件以及文件夹 md : 创建目录 rd : 删除目录 cd : 进入指定目录 cd.. : 退回到上一级目录 cd/ : 退回到 ...
- Java基础语法04面向对象上-类-属性-方法-可变参数-重载-递归-对象数组
类 面向对象是一种思想,一般指将事务的属性与方法抽出总结为模板(类/class),处理事务时通过类创建/new出对象由对象的功能/方法去完成所要计算处理的事情. 面向过程:POP:以过程,步骤为主,考 ...
- javascript基础语法——变量和标识符
× 目录 [1]定义 [2]命名规则 [3]声明[4]特性[5]作用域[6]声明提升[7]属性变量 前面的话 关于javascript,第一个比较重要的概念是变量,变量的工作机制是javascript ...
随机推荐
- ubuntu和win10设置双显示器
ubuntu:最右上角那个图标,点开找到系统设置,系统设置中找到“显示”中,在其中可以调节双屏显示或者只显示一个屏,图等会补... win10:现在是ubuntu系统所以操作忘记了写不出来,等下换系统 ...
- ubuntu安装搜狗输入法后无法使用goland的快捷键 ctrl+alt+B
安装了搜狗拼音后,其快捷键ctrl+alt+b会启动软键盘,造成与其他编辑器快捷键的冲突. 为了禁止使用ctrl+alt+b启动软键盘,可以: 1. 在搜狗拼音输入法选择设置 2. 高级设置 3. 高 ...
- CSS基础强化
1. 浮动引起元素变成行内块元素-display:inline-block <div style="width: 400px;height: 200px;"> < ...
- JS---案例:开机动画
案例:开机动画 由上下两部分组成,先下面的高变为0 ,再最大的div宽为0,形成一个缩小到没有的动画效果 点击的X是在背景图上的,在上面设置了一个空的span用于注册点击事件 <!DOCTYPE ...
- Vue.之. 动态设置按钮Disabled
Vue.之. 动态设置按钮Disabled 按钮代码如下: 添加了一个 属性 :disabled="isAble" ,控制:更新按钮.重置按钮 <el-form- ...
- 【Vue】详解组件的基础与高级用法
Vue.js 最核心的功能就是组件(Component),从组件的构建.注册到组件间通信,Vue 2.x 提供了更多方式,让我们更灵活地使用组件来实现不同需求. 一.构建组件 1.1 组件基础 一个组 ...
- [java]java构造器 标签: java面向对象 2017-06-11 11:16 195人阅读 评论(12)
构造器这个概念,各种语言都有出现,虽然为了考试或者其他学了好多遍,但是自己一直不能理解这个概念,前几天又学了一遍,突然就明白了,下面随小编来一起学习一下吧. 什么是构造器? 在类别基础的面向对象程序设 ...
- IE下的双外边距浮动bug
最常见且最容易发现的额一个bug是IE 6和最低版本中的双外边距浮动bug.这个bug是任何浮动元素上的外边距加倍. 上面代码中,div盒子向左边浮动,设置的margin-left的值是10px.在c ...
- 【转载】【python】python练手项目
入门篇 1.Python - Python 图片转字符画 50 行 Python 代码完成图片转字符画小工具. <img src="https://pic3.zhimg.com ...
- vue 保存数组和对象, 避免双向绑定影响
很多时候需要保存数据然后复用该数据,因vue的双向绑定总是不能保存原始数据 随笔记录解决方式 1. 不要把变量放置在data中 2. 保存至新的变量 object : let obj= Objec ...