reactive和TypeScript标注数据类型-ts使用方法

一、vite项目中<script setup lang="ts"> : lang="ts" 是表明支持ts校验(ts 全称typescript,是es6语法,是javascript的超集强类型编程语言,类似java,定义变量类型后,赋值类型不一致,会提示,但是可以运行

国内网址:TypeScript中文网 · TypeScript------JavaScript的超集

如果声明类型和设置值类型不一致会有提示,如图

不能将类型"string"分配给类型"number"。ts(2322),

二、使用接口声明数据类型 interface,ps:interface关键字要<script setup lang="ts"> 加上lang="ts"不然会报错

例子如下:

html 复制代码
//http://tslang.cn/docs/handbook/interfaces.html
  interface User {//接口名称首字母大写
    id:number;
    name:string;
  }
  const user2:User=reactive({
    id:true,
    name:'小龙'
  })

完整例子如下:

html 复制代码
<script setup lang="ts"> //lang="ts" 是表明支持ts校验
  /**
   * vue3+typescript语法
   * 上面要加 lang="ts" 下面写的代码都是基于ts强类型
   */
  import {reactive} from 'vue';
  //默认会推导得到对应的数据类型:{id:number,name:string}
  const state = reactive({
    id: 123,
    name: '李四'
  });
  //不能将类型"string"分配给类型"number"。ts(2322),
  //state.id='345';

  //使用接口声明数据类型 interface
  //http://tslang.cn/docs/handbook/interfaces.html
  interface User {//接口名称首字母大写
    id:number;
    name:string;
  }
  const user2:User=reactive({
    id:234,
    name:'小龙'
  })
  //user2.id=true
  user2.id=4556
</script>

<template>
  <div>
    {{ state.id }}
  </div>
</template>

<style scoped>

</style>

小知识:

es3 的时候,声明变量例如

var i=1; 修改变量值i='1232' ,可以随时变

let b=true;修改变量值 b='sss',也可随时变

es6

声明常量 const i=1,修改变量值 i='sss',值不会改变

相关推荐
HarderCoder3 分钟前
ByAI:Rect-redux实现及connect函数
前端·react.js
小张快跑。5 分钟前
【Vue3】(三)vue3中的pinia状态管理、组件通信
前端·javascript·vue.js
我想说一句5 分钟前
当 map 遇上 parseInt:JS 中一场参数引发的“血案”
前端·javascript·面试
陈随易5 分钟前
2025年100个产品计划之第12个(杰森排序) - 对 JSON 属性进行排序
前端·后端·程序员
LeeAt6 分钟前
《谁杀死了比尔?》:使用Trae完成的一个推理游戏项目!!
前端·游戏开发·trae
三气归来7 分钟前
2. 内置模块之http模块
javascript·后端
FogLetter8 分钟前
🧙‍♂️ 魔法笔记:JavaScript 词法作用域与闭包的神秘世界
javascript·后端
Hockor10 分钟前
写给前端的 Python 教程四(列表/元组)
前端·后端·python
GetcharZp10 分钟前
「DPlayer」超强弹幕视频播放器来了!支持m3u8直播,5分钟搞定集成!
前端
天天码行空14 分钟前
Bootstrap Table企业级web数据表格集成框架
前端·javascript·开源