当前位置: 首页 > article >正文

TypeScript 快速实战系列:基础入门|TypeScript 核心语法 1 小时吃透(必备基础)

导读上一篇我们搞定了TS环境搭建也搞懂了为什么大模型开发必须学TS。今天这篇不搞复杂理论只讲大模型开发中「最常用、最核心」的TS语法——基础类型类型注解1小时就能吃透学完就能给大模型API参数、返回值做类型定义彻底告别“参数传错”的坑适合人群零基础、前端/AI开发新手全程实战每一行代码都能直接复制运行结合大模型场景讲解不学没用的语法。一、先搞懂TS与JS的核心区别一句话说透很多人分不清TS和JS的关系其实很简单TypeScript JavaScript 类型系统也就是说所有JS代码都是合法的TS代码但TS多了“类型约束”——你可以给变量、函数参数、返回值定义“类型”告诉TS这个值应该是什么样子写错了就会直接报错。举个大模型开发中的例子// JS代码没有类型约束传错类型也不报错运行时才崩const temperature 0.7; // 应该是数字却传了字符串// TS代码有类型约束传错类型直接报错写代码时就提醒const temperature: number 0.7; // 报错类型“string”不能赋值给类型“number”这就是TS的核心价值——提前规避错误尤其在大模型API调用中参数类型繁多有了类型约束能少踩很多坑。二、大模型开发最常用的5种基础类型必记TS的基础类型有很多但大模型开发中常用的只有5种记住它们就能搞定80%的基础场景不用记所有类型1. 字符串类型string用途大模型API密钥apiKey、模型名称model、对话内容content、请求地址url等都是字符串类型。// 语法变量名: 类型 值const apiKey: string sk-xxxxxxxxxxxxxxxx; // 大模型API密钥const model: string qwen-max; // 通义千问模型名称const userContent: string 用TS写一个大模型调用函数; // 用户对话内容2. 数字类型number用途大模型的temperature温度0~2、max_tokens最大生成 tokens 数、top_p等参数都是数字类型。const temperature: number 0.7; // 控制生成内容的随机性const maxTokens: number 1000; // 最大生成 tokens 数const topP: number 0.9; // 控制生成内容的多样性3. 布尔类型boolean用途大模型的stream流式输出true/false、是否开启调试模式等都是布尔类型。const stream: boolean true; // 开启流式输出打字机效果const debug: boolean false; // 关闭调试模式4. 任意类型any用途临时不确定类型的值比如大模型返回的复杂数据暂时不知道结构但尽量少用——用多了就失去了TS的类型约束意义是大模型开发中最容易踩的坑。// 临时使用尽量避免let llmResponse: any {}; // 暂时不知道返回结构先用any⚠️ 避坑提醒如果长期用any定义大模型返回值就等于放弃了TS的智能提示和类型校验和用JS没区别后续会踩更多坑。5. 未知类型unknown用途替代any的“安全版本”当你不确定类型时用unknown比any更安全——unknown类型的值不能直接使用必须先判断类型才能操作。let llmResponse: unknown hello world;// 不能直接使用必须先判断类型if (typeof llmResponse string) {console.log(llmResponse.length); // 此时确定是string类型才能调用length}大模型开发中接收API返回值时用unknown比any更安全避免误操作。三、核心语法类型注解大模型开发必用类型注解就是“给变量、函数参数、返回值贴标签”告诉TS它们的类型语法非常简单标识符: 类型。下面结合大模型开发场景讲解3种最常用的类型注解学完就能直接用。1. 变量的类型注解最基础就是给变量定义类型前面讲基础类型时已经用过了再汇总一个大模型场景的示例// 大模型请求相关变量的类型注解 const apiKey: string sk-xxxxxxx; const model: string gpt-3.5-turbo; const temperature: number 0.7; const stream: boolean true; const baseUrl: string https://api.openai.com/v1/chat/completions;这样定义后只要给这些变量赋值错误的类型TS就会直接报错提前规避问题。2. 函数参数的类型注解大模型开发中我们会写很多调用API的函数给函数参数加类型注解能避免传错参数类型。// 示例定义一个大模型请求参数的函数 function getLlmParams( model: string, // 模型名称字符串类型 temperature: number, // 温度数字类型 stream: boolean // 流式输出布尔类型 ) { return { model, temperature, stream, messages: [], // 后续会讲暂时空数组 }; } // 正确调用参数类型匹配 getLlmParams(qwen-max, 0.7, true); // 错误调用temperature传了字符串直接报错 getLlmParams(qwen-max, 0.7, true); // 报错类型“string”不能赋值给类型“number”3. 函数返回值的类型注解给函数返回值加类型注解能明确函数返回的是什么类型方便后续使用也能避免函数返回错误的值。// 定义函数返回值类型对象类型后续会详细讲这里先了解 function getLlmParams( model: string, temperature: number, stream: boolean ): { model: string; temperature: number; stream: boolean; messages: [] } { return { model, temperature, stream, messages: [], }; } // 调用函数能明确知道返回的结构和类型 const params getLlmParams(qwen-max, 0.7, true); console.log(params.model); // 智能提示model是string类型四、实战小任务定义一个「大模型请求配置」类型变量学完上面的内容我们来做一个实战小任务直接贴合大模型开发场景巩固今天的知识点——定义一个完整的大模型请求配置变量包含所有常用参数。// 实战定义大模型请求配置 const llmConfig: { apiKey: string; model: string; temperature: number; stream: boolean; maxTokens: number; baseUrl: string; } { apiKey: sk-xxxxxxxxxxxxxxxx, model: gpt-3.5-turbo, temperature: 0.7, stream: true, maxTokens: 1000, baseUrl: https://api.openai.com/v1/chat/completions, }; // 打印配置验证是否正确 console.log(大模型请求配置, llmConfig);将这段代码复制到index.ts文件中用ts-node index.ts运行能正常打印配置就说明你掌握了今天的知识点五、避坑指南大模型开发中TS最容易踩的坑滥用any类型这是最常见的坑很多人觉得any方便什么都用any结果失去了TS的类型约束和用JS没区别忽略类型报错写代码时TS提示类型错误觉得“能运行就行”强行忽略后续会出现各种诡异的bug给变量赋值错误类型比如把大模型的temperature赋值为字符串虽然JS能运行但TS会报错一定要按照定义的类型赋值。六、本篇总结下一篇预告✅ 核心收获掌握了大模型开发最常用的5种基础类型学会了变量、函数参数、返回值的类型注解能独立定义大模型请求配置变量❌ 避坑提醒少用any类型重视TS的类型报错养成“先定义类型再写代码”的习惯 下一篇预告《核心进阶Interface Type大模型开发神器》带你学会用Interface和Type定义复杂的大模型请求/返回类型彻底解决“返回值字段找不到”的问题直接搞定80%的LLM开发TS需求 评论区互动今天的语法你学会了吗试着自己写一个大模型请求配置变量留言贴出你的代码一起交流进步

相关文章:

TypeScript 快速实战系列:基础入门|TypeScript 核心语法 1 小时吃透(必备基础)

🔥 导读:上一篇我们搞定了TS环境搭建,也搞懂了为什么大模型开发必须学TS。今天这篇,不搞复杂理论,只讲大模型开发中「最常用、最核心」的TS语法——基础类型类型注解,1小时就能吃透,学完就能给大…...

Windows环境下SeaweedFS的快速部署与实战指南

1. 五分钟搞定SeaweedFS Windows安装 第一次听说SeaweedFS时,我也被这个"海草文件系统"的名字逗笑了。但别被名字迷惑,它可是个正经的分布式文件存储系统,特别适合处理海量小文件。我在Windows上部署过好几次,发现比想象…...

OBS屏幕录制全攻略:从零开始轻松上手

1. OBS屏幕录制入门指南 第一次接触OBS的朋友可能会被它复杂的界面吓到,但其实它的核心功能非常简单。我刚开始用OBS时也走了不少弯路,现在就把这些经验分享给大家。OBS Studio(Open Broadcaster Software)是一款开源免费的屏幕录…...

告别杂乱飞线!用Allegro约束管理器高效规划你的单片机板卡布局布线

告别杂乱飞线!用Allegro约束管理器高效规划你的单片机板卡布局布线 在单片机板卡设计中,工程师们常常面临一个共同的痛点:随着元件密度增加和信号速率提升,传统的"先布局后修补"模式会导致后期出现大量飞线交叉、电源噪…...

别再只会apt autoremove了!dpkg报错Sub-process returned error code (1)的5种修复姿势全解析

深度解析dpkg报错Sub-process returned error code (1)的5种专业修复策略 当你正在Ubuntu或Debian系统上安装某个关键软件包时,突然终端弹出一条刺眼的错误信息:"Sub-process /usr/bin/dpkg returned an error code (1)"。这不是普通的警告&am…...

手把手教你用STM32CubeMX和HAL库驱动DW3000:从SPI配置到第一个测距Demo

零基础玩转DW3000:STM32CubeMXHAL库实现厘米级UWB测距全指南 当我们需要在仓库里快速定位某个货架上的商品,或是让扫地机器人精准识别家具位置时,传统GPS和蓝牙方案的精度往往捉襟见肘。这正是UWB(超宽带)技术大显身手…...

**基于Python与BCI接口的脑机交互编程实践:从信号采集到实时控制的全流程实

基于Python与BCI接口的脑机交互编程实践:从信号采集到实时控制的全流程实现 在人工智能与神经科学融合加速发展的今天,脑机接口(Brain-Computer Interface, BCI) 正逐渐从实验室走向实用化场景。本文将带你深入一个完整的 Python驱…...

**发散创新:基于Python的本体推理与知识表示实战解析**在人工智能和语义网技术飞速发展的今天,**知识表

发散创新:基于Python的本体推理与知识表示实战解析 在人工智能和语义网技术飞速发展的今天,知识表示(Knowledge Representation) 已成为构建智能系统的底层核心能力之一。它不仅决定了系统对现实世界的理解深度,还直接…...

07_Neo4j知识体系之向量搜索与GraphRAG实战

07_Neo4j知识体系之向量搜索与GraphRAG实战 体系 AI 增强层:向量索引、相似度搜索、GraphRAG 架构、LLM 集成、知识图谱增强问答关联能力:与企业搜索、智能问答、多跳推理、知识组织、Agent 系统密切相关适用对象:AI 应用架构师、RAG 工程师、…...

08_Neo4j知识体系之企业级特性与高可用架构

08_Neo4j知识体系之企业级特性与高可用架构 体系 企业特性层:集群与高可用、安全与合规、备份恢复、监控运维、Neo4j Ops Manager关联能力:与关键业务系统、金融级稳定性、多环境治理、权限审计、灾备体系密切相关适用对象:企业架构师、DBA、…...

06_Neo4j知识体系之AuraDB云服务与部署实战

06_Neo4j知识体系之AuraDB云服务与部署实战 体系 云服务层:AuraDB 完全托管、版本层级、定价模式、AWS/Azure/GCP 集成、弹性扩展、高可用、快速开始关联能力:与企业上云、GraphRAG 交付、低运维团队部署、全球可用区建设密切相关适用对象:云…...

深度解析:Agent 如何处理“开放性目标”与“约束性规则”的冲突?

深度解析:Agent 如何处理“开放性目标”与“约束性规则”的冲突? 1. 引言 (Introduction) 1.1 核心概念锚定与常见误解破冰 在正式展开冲突处理的技术细节之前,我们必须先锚定文章涉及的三个最核心、最容易被模糊定义/误解的AI Agent领域概念…...

Flutter Provider:简单而强大的状态管理

Flutter Provider:简单而强大的状态管理告别 setState 的混乱,拥抱 Provider 的简洁优雅。一、Provider 的核心价值 作为一名追求代码如散文般优雅的 UI 匠人,我对状态管理工具有着严格的要求。Provider 不仅解决了 Flutter 中的状态共享问题…...

AI Agent在智能制造中的应用:多智能体协同生产调度案例

AI Agent在智能制造中的应用:多智能体协同生产调度案例 摘要/引言 各位读者好,我是深耕工业软件与分布式AI系统近十年的技术博主,也是前西门子离散制造数字化转型中心的架构师。今天这篇文章,我们要聊的绝对是当前智能制造领域最…...

CSS 嵌套:编写更优雅的样式代码

CSS 嵌套:编写更优雅的样式代码让 CSS 结构更清晰,层次更分明,代码更易维护。一、CSS 嵌套的优势 作为一名把代码当散文写的 UI 匠人,我对代码的可读性和结构有着近乎偏执的要求。CSS 嵌套让我们能够按照 HTML 的层次结构来组织样…...

Flutter 微交互:细节中的用户体验魔法

Flutter 微交互:细节中的用户体验魔法小细节,大体验。微交互让应用更有生命力。一、什么是微交互? 作为一名追求像素级还原的 UI 匠人,我深知微交互的力量。它们是用户与界面之间的微小对话——一个按钮的按下反馈、一个列表项的滑…...

09_Neo4j知识体系之行业应用与最佳实践

09_Neo4j知识体系之行业应用与最佳实践 体系 行业应用层:金融反欺诈、智能推荐、社交网络分析、知识图谱构建、供应链优化关联能力:与图建模、路径分析、图算法、GraphRAG、实时决策和企业数据治理密切相关适用对象:解决方案架构师、行业数字…...

《WebPages 邮局》

《WebPages 邮局》 引言 在互联网的海洋中,WebPages 邮局犹如一座灯塔,为无数用户指引着信息传递的航向。本文将深入探讨 WebPages 邮局的功能、优势以及其在信息时代的重要地位。 WebPages 邮局的功能 1. 邮件收发 WebPages 邮局的核心功能是邮件收发。用户可以通过 We…...

Kubernetes 部署 Spring Boot 应用:从入门到生产实践

Kubernetes 部署 Spring Boot 应用:从入门到生产实践 别叫我大神,叫我 Alex 就好。 一、引言 大家好,我是 Alex。Kubernetes 已经成为云原生应用部署的事实标准,而 Spring Boot 是 Java 微服务开发的首选框架。今天,我…...

Python数据类配置模式详解

在现代Python应用开发中,配置管理是一个关键环节。今天我们来深入分析一个优雅的配置管理实现,它展示了如何将环境变量配置与数据类完美结合。 核心概念 让我们先看一个典型的配置类实现: from __future__ import annotations import os from…...

深入理解Python @dataclass:从基础到高级用法

Python 3.7引入了dataclass装饰器,这是一个强大的工具,能够显著减少数据类的样板代码。本文将详细介绍dataclass的各种用法,特别是如何正确处理可变默认值和类型注解。 什么是dataclass dataclass是位于dataclasses模块中的装饰器&#xff0c…...

手把手教你用RFSoC ZU47DR的DAC/ADC:从单音信号到1200MHz宽带调制的避坑实践

手把手教你用RFSoC ZU47DR的DAC/ADC:从单音信号到1200MHz宽带调制的避坑实践 当一块开发板的价格抵得上半辆家用轿车时,每个操作步骤都值得反复推敲。这就是RFSoC ZU47DR给我的第一印象——强大到令人兴奋,复杂到让人却步。作为赛灵思第三代射…...

jEasyUI 显示海量数据

jEasyUI 显示海量数据 引言 随着互联网技术的飞速发展,大数据时代已经到来。在众多前端框架中,jEasyUI以其简洁、易用、功能强大等特点,受到了广大开发者的喜爱。本文将深入探讨jEasyUI在显示海量数据方面的应用,帮助开发者更好地应对大数据挑战。 jEasyUI简介 jEasyUI…...

Matlab仿真研究:三机并联风光混合储能并网系统的建模与控制策略实现

Matlab仿真三机并联风光混合储能并网系统,风光储并网,微电网系统,光伏电池模型,永磁同步风机,电压电流控制,PQ控制 波形正确,结构完整有参考文献,详情见图片 三机并联风光混合储能并…...

基于Yolov5的钢轨表面缺陷检测:数据集与含训练好的模型

基于yolov5的钢轨表面缺陷检测 数据集含训练好的模型一、项目概述 本项目基于YOLOv5 7.0版本构建,专注于钢轨表面缺陷检测任务,提供了完整的模型训练、推理、导出及性能评估工具链。项目包含47个核心文件,涵盖数据加载、模型构建、训练优化、…...

永磁同步电机参数辨识全解析:从原理到代码实现

永磁同步电机参数辨识 提供原理图、PCB和BOM表及文档说明 永磁同步电机参数辨识 包括初始位置检测,编码器零点位置、方向辨识; 包括电机极对数、电阻、电感、磁链、反电势常数、编码器零位等 包括源C代码,代码详细注释文档,可见…...

基于VSC控制的400kW光伏并网发电厂模型

基于VSC控制的400kW光伏并网发电厂模型simulink模型各模块清晰明白,非常适用于新手入门学习大家好!今天我要和大家分享一个关于光伏并网发电厂模型的Simulink仿真项目。这个模型基于电压源式开关(VSC)控制,非常适合400…...

AI时代程序员必看!揭秘Harness Engineerin

当AI智能体开始批量编写代码,程序员会失业吗?OpenAI的一个实验给出了惊人答案:在一次实验中,3名工程师配合1500个AI智能体,竟在5个月内完成了100万行代码的产品开发——人类一行代码都没写!但背后真正的秘密…...

MTKClient技术内幕:从硬件交互到场景落地的深度探索

MTKClient技术内幕:从硬件交互到场景落地的深度探索 【免费下载链接】mtkclient MTK reverse engineering and flash tool 项目地址: https://gitcode.com/gh_mirrors/mt/mtkclient 一、技术原理解析:MTKClient如何与硬件对话 MTKClient的核心能…...

华泰证券2027届校招启动|提前批+国际管培+金融科技,三个专场一次说清

导读很多同学还在等“春招后半场捡漏”,但现实已经变了。头部企业的优质岗位,正在通过提前批 专项项目提前锁定人选。如果你现在才开始准备,很可能连入场资格都拿不到。这次华泰证券的校招,就是一个非常典型的信号:提…...