3. typescript的扩展类型 - 枚举

扩展类型 - 枚举

扩展类型:类型别名、枚举、接口、类

枚举通常用于约束某个变量的取值范围。

字面量和联合类型配合使用,也可以达到同样的目标。

字面量类型的问题

  • 在类型约束位置,会产生重复代码。可以使用类型别名解决该问题。 在这里插入图片描述

  • 逻辑含义和真实的值产生了混淆,会导致修改真实值得时候,产生大量得修改。
    这是什么意思呢,如果在大中型项目里面,需要改变性别的值。改成帅哥和美女,需要进行大量的修改。但是帅哥和男的逻辑含义是一样的。而枚举可以解决这个问题。

  • 字面量类型不会进入编译结果。
    在这里插入图片描述
    可以发现,最终的编译结果没有字面量类型取值范围。如果需要动态的取值,字面量类型有很大的局限性。

枚举

如何定义一个枚举

enum 枚举名 {
    枚举字段1 = 值1,
    枚举字段2 = 值2
}

在这里插入图片描述

枚举会出现到编译结果中。
在这里插入图片描述

枚举的规则:

  • 枚举的字段值可以是字符串或数字
    数字枚举的值会自动自增(有初始值则按初始值递增,否则从0开始)
  • 被数字枚举约束的变量,可以直接赋值为数字(最好不用,尽量使用逻辑名称)。
  • 数字枚举的编译结果 和 字符串枚举有差异

最佳实践

  • 尽量不要再一个枚举中既出现字符串字段,又出现数字字段。
  • 使用枚举时,尽量使用枚举字段的名称,而不是真实的值
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. Vue3相较于Vue2有以下不同之处: - 更好的性能:Vue3通过Proxy代理对象实现了更高效的响应式系统,提升了性能。 - 更小的体积:Vue3进行了重构,移除了一些不常用的API,使得整个库的体积更小。 - Composition API:Vue3引入了Composition API,提供了一种更灵活的组件组织方式,使得逻辑复用更简便。 2. Setup函数是Vue3中的一个新特性,它用于替代Vue2中的选项API中的created和mounted钩子函数。Setup函数在组件创建阶段执行,在组件实例化之前运行,可以用来初始化组件的响应式数据、引入组件所需的依赖等操作。 3. ref函数的使用步骤如下: ``` import { ref } from 'vue'; const count = ref(0); // 创建一个响应式的数据 console.log(count.value); // 访问响应式数据 count.value++; // 修改响应式数据 ``` 4. reactive函数的使用步骤如下: ``` import { reactive } from 'vue'; const state = reactive({ count: 0 }); // 创建一个响应式对象 console.log(state.count); // 访问响应式对象的属性 state.count++; // 修改响应式对象的属性 ``` 5. ref跟reactive的区别: - ref用于创建一个单一的响应式数据,而reactive用于创建一个响应式对象,可以包含多个属性。 - ref返回的是一个包装过的对象,需要通过`.value`来访问和修改数据,而reactive返回的是原始对象,可以直接访问和修改属性。 6. Vue3中计算属性的使用与Vue2类似,通过`computed`函数来定义计算属性: ``` import { computed } from 'vue'; const doubleCount = computed(() => count.value * 2); console.log(doubleCount.value); // 访问计算属性 ``` 7. Vue3中watch的使用方式也有所改变,在setup函数中使用`watch`函数来监听响应式数据的变化: ``` import { watch } from 'vue'; watch(count, (newValue, oldValue) => { console.log('count has changed:', newValue); }); ``` 8. watchEffect函数是Vue3中的一个新函数,它会立即执行传入的副作用函数,并在依赖的响应式数据发生变化时重新执行。主要用于执行一些具有副作用的操作,例如发送网络请求等。 9. Vue2与Vue3的生命周期钩子函数有以下区别: - Vue2中有beforeCreate和created两个钩子函数,而Vue3中使用setup函数替代了这两个钩子函数。 - Vue3中去除了beforeMount和mounted钩子函数,而使用onBeforeMount和onMounted替代。 - Vue3中去除了beforeUpdate和updated钩子函数,而使用onBeforeUpdate和onUpdated替代。 - Vue3中去除了beforeDestroy和destroyed钩子函数,而使用onBeforeUnmount和onUnmounted替代。 10. toRef和toRefs函数的作用是将响应式对象的属性转换为单独的ref对象。toRef用于将单个属性转换为ref对象,而toRefs可以一次性将整个响应式对象的所有属性转换为ref对象。 ``` import { toRef, toRefs, reactive } from 'vue'; const state = reactive({ count: 0, title: 'Hello' }); const countRef = toRef(state, 'count'); // 将count属性转换为ref对象 const refs = toRefs(state); // 将整个响应式对象的所有属性转换为ref对象 console.log(refs.count.value); console.log(refs.title.value); ``` 11. 除了前面提到的,Vue3还引入了Teleport组件用于实现跨组件的Portal功能,Suspense组件用于实现异步组件加载和错误处理等新特性。 12. TypeScript是一种静态类型检查的编程语言,它是JavaScript的超集,可以编译为纯JavaScript代码。与JavaScript相比,TypeScript具有以下特点: -类型TypeScript具有静态类型检查机制,可以在编译阶段发现类型错误。 - 类型推断:TypeScript可以根据变量的赋值推断出变量的类型,减少显式类型声明的需求。 - 更丰富的面向对象特性:TypeScript支持类、接口、泛型等面向对象的特性。 - 更好的工具支持:TypeScript具有更完善的编辑器支持和开发工具链。 13. TypeScript中包含以下数据类型- 基本类型:number、string、boolean、null、undefined、symbol。 - 数组类型:number[]、string[]等。 - 元组类型:[number, string]等。 - 对象类型:{ key: value }等。 - 函数类型:(param: type) => returnType等。 -类型:enum。 - 泛型类型:Array<number>等。 14. TypeScript中的接口用于定义对象的结构和类型。属性接口用于定义对象的属性结构,函数类型接口用于定义函数的参数和返回值的类型- 属性接口示例: ``` interface Person { name: string; age: number; } const person: Person = { name: 'John', age: 25 }; ``` - 函数类型接口示例: ``` interface AddFunc { (a: number, b: number): number; } const add: AddFunc = (a, b) => a + b; ``` 15. 除了前面提到的Vue3的新特性外,ES6后的一些常用特性还包括箭头函数、解构赋值、模板字符串、扩展运算符、Promise等。箭头函数可以简化函数的定义和使用;解构赋值可以方便地从对象或数组中提取值;模板字符串可以方便地拼接字符串和插入变量;扩展运算符可以方便地合并对象和数组;Promise可以更好地处理异步操作。 16. Vue3是一种渐进式JavaScript框架,可以用于构建用户界面。它通过响应式系统和组件化开发模式,使得开发者可以更方便地构建复杂的Web应用程序。 17. 这段代码中的三个属性在TypeScript中的意思是: - upState: 表示一个字符串或数字类型的属性。 - keyword: 表示一个字符串类型的属性。 - sendMsgState?: 表示一个可选的字符串或数字类型的属性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值