Vue3+TypeScript从入门到精通系列之:抽象类

一、TypeScript抽象类

(() => {

//抽象类:包含抽象方法,也可以包含实例方法
//抽象类不能被实例化,让子类进行实例化嗯及实现

//定义一个抽象类
abstract class Animal{
//抽象属性
abstract name: string
//抽象方法
abstract eat()

//实例方法
say(){
console.log(this.name,"都是动物")
}

}

class Dog extends Animal{
name: string = "小狗"
eat(){
  console.log(this.name,"喜欢吃骨头")
}
}

//实例化Dog对象
const dog:Dog = new Dog()
dog.eat()
dog.say()


})()

二、TypeScript抽象类代码转化为js代码

tsc ./抽象类.ts

抽象类.js代码如下所示:

var __extends = (this && this.__extends) || (function () {
    var extendStatics = function (d, b) {
        extendStatics = Object.setPrototypeOf ||
            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
        return extendStatics(d, b);
    };
    return function (d, b) {
        if (typeof b !== "function" && b !== null)
            throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
        extendStatics(d, b);
        function __() { this.constructor = d; }
        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
    };
})();
(function () {
    //抽象类:包含抽象方法,也可以包含实例方法
    //抽象类不能被实例化,让子类进行实例化嗯及实现
    //定义一个抽象类
    var Animal = /** @class */ (function () {
        function Animal() {
        }
        //实例方法
        Animal.prototype.say = function () {
            console.log(this.name, "都是动物");
        };
        return Animal;
    }());
    var Dog = /** @class */ (function (_super) {
        __extends(Dog, _super);
        function Dog() {
            var _this = _super !== null && _super.apply(this, arguments) || this;
            _this.name = "小狗";
            return _this;
        }
        Dog.prototype.eat = function () {
            console.log(this.name, "喜欢吃骨头");
        };
        return Dog;
    }(Animal));
    //实例化Dog对象
    var dog = new Dog();
    dog.eat();
    dog.say();
})();

三、js输出如下所示

node ./抽象类.js
小狗 喜欢吃骨头
小狗 都是动物
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Vue3 + TypeScript 是一种常用的前端开发技术组合,它结合了Vue框架的便捷性和TypeScript型检查能力,可以提高项目的可维护性和开发效率。下面是一些Vue3 + TypeScript项目经验的介绍: 1. 项目初始化:使用Vue CLI创建一个Vue3项目,并选择TypeScript作为项目的语言。这样可以自动生成一些基本的配置和文件结构,方便快速开始开发。 2. 型定义:在Vue3 + TypeScript项目中,可以使用TypeScript型系统来定义组件的props、data、computed等属性的型,以及事件的参数型等。这样可以在编码过程中及早发现潜在的型错误,提高代码的健壮性。 3. 组件开发:在Vue3 + TypeScript项目中,可以使用装饰器(decorators)来定义组件选项,例如使用@Prop来定义props属性的型,使用@Emit来定义事件的参数型。这样可以更清晰地描述组件的接口和行为。 4. 路由管理:在Vue3 + TypeScript项目中,可以使用Vue Router进行路由管理。通过定义路由的型和参数型,可以在编码过程中获得更好的型提示和错误检查。 5. 状态管理:在Vue3 + TypeScript项目中,可以使用Vuex进行状态管理。通过定义状态的型和操作的参数型,可以提高代码的可读性和可维护性。 6. 第三方库的使用:在Vue3 + TypeScript项目中,可以使用第三方库,并为其编写型声明文件,以获得更好的型检查和代码提示。例如,可以使用axios发送HTTP请求,并为其编写型声明文件,以确保请求参数和响应数据的型正确。 7. 单元测试:在Vue3 + TypeScript项目中,可以使用Jest等测试框架进行单元测试。通过编写型安全的测试用例,可以提高代码的质量和可靠性。 8. 构建和部署:在Vue3 + TypeScript项目中,可以使用Webpack等构建工具进行项目的打包和优化。通过配置合适的TypeScript编译选项和Webpack插件,可以生成高效的生产环境代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

最笨的羊羊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值