TypeScript小白初体验之前后端交互

前提:有TS环境配置,有运行VSCode基本经历;

  1. 环境配置:打开任意新文件夹,新建文件:tsconfig.json用于ts配置,内容包括:
    {
        "compilerOptions":{
            "module": "commonjs",
            "sourceMap": true,
            "outDir": "dist",
            "declaration": true,
            "experimentalDecorators": true,
            "removeComments": false,
            "noImplicitAny": true,
            "preserveConstEnums": true,
            "target": "es2018"
        },
        "exclude": [
            "node_modules"
        ]
    }

     

  2. 相关文件夹新建:先新建src/index.ts这点很重要,防止无法找到主目录)再新建src/controller(用于文件调用)
  3. 打开终端:分界面:1界面输入:tsc -w ;1界面输入:yarn 或者 yarn init -y 用于初始化;初始化完成后,输入:
    yarn add @ctsy/server @ctsy/controller @ctsy/model @ctsy/relation @ctsy/config @ctsy/router @types/node 
     用于依赖包的安装。安装完成后,可以在 node_modules 文件夹中找到这些依赖包
  4. 打开index.ts文件,输入: 用于配置后台服务
    import server from '@ctsy/server'
    import {install as RouterInstall} from '@ctsy/router'
    server.install({install : RouterInstall})
    server.start(9600);//设置端口

     

  5. src/controller文件夹新建文件 A.ts 并写入相关函数: 用于确定交互成功
    export default class A{
        a(){
            return 1;
        }
    
        b(){
            return 2;
        }
    }

     

  6. 开始配置调试文件:打开 .vscode/launch.json 文件,输入相关,再在调试处点击 server-9600 开始运行
    {
                "type": "node",
                "request": "launch",
                "name": "server-9600",
                "cwd": "${workspaceFolder}",
                "program": "${workspaceFolder}/dist/index.js"
            },

     

  7. 浏览器中输入 http://localhost:9600/A/a 和  http://localhost:9600/A/b 根据对应结果确定是否完成交互,返回:                  a:{"d":1,"c":200,"i":"","e":""}        b:{"d":2,"c":200,"i":"","e":""}     即表明交互成功
  8. 升级:调用本地文件并显示: 新建文件夹data ,添加文件 test.txt ;将 A.ts 文件修改为:
    import { readFile } from "fs";
    export default class A{
        a(){
            return 1;
        }
    
        b(){
            return 2;
        }
        fun(){
            return new Promise((s)=>{
            //调用文件:test.txt
                readFile('data/test.txt',(e,d)=>{
                    s(d.toString())
                })
            })
        }
    }

    打开文件 test.txt(文本),添加任意内容,保存后运行,浏览器输入:http://localhost:9600/A/fun,于 “d”:中显示相关内容。

  9. 数据库扩展:在src下新建db/test.ts,输入: 用于对数据库中某一数据的获取
import { DbDataType } from "@ctsy/model";
export default {
    //声明一个类型为整形的数据库表
    UID:{
        primaryKey:true,
        type:DbDataType.bigint,
    }
}

       修改调试文件:用于对数据库的获取

 {
            "type": "node",
            "request": "launch",
            "name": "DB",
            "program": "${workspaceFolder}/dist/index.js",
            "env": {
                "DB_HOST":"127.0.0.1",
                "DB_NAME":"test",
                "DB_USER":"root",
                "DB_PWD":"123456",
                "DB_PORT":"3306"
            }
        },

在src的contoller中新建db.ts,输入:与之前的A.ts类似的功能,通过select查找一个名为test的数据库表:

import BaseController from "@ctsy/controller/dist/base_controller";

export default class db extends BaseController{
    async select(){
        return await this.M('test').select();
    }
}

然而在调试显示过程中: http://localhost:9600/db/select/ 输出为:

{"d":"","c":404,"i":"","e":{"m":"DB_DEFINE_NOT_FOUND:test"}}  即文件不存在

这时候试着将vscode重启,并删除dist文件夹,修改db下文件名,再重新编译tsc -w,再去数据库端查看test库中是否有表test,表内UID对应的添加数据,对应用户root修改插件为mysql_native_password;再网页刷新:

http://localhost:9600/db/select 输出为: {"d":[{"UID":1},{"UID":2}],"c":200,"i":"","e":""} 表示获取到数据中的内容。获取数据库数据完成。

添加数据至数据库:在db.ts文件中添加函数add如下:

async add(){

return await this.M('test').add({UID:8})

}

通过调用 http://localhost:9600/db/add 直接输出: {"d":{"UID":8},"c":200,"i":"","e":""}  

通过再次调用 http://localhost:9600/db/selec直接输出: {"d":[{"UID":1},{"UID":2},{"UID":8}],"c":200,"i":"","e":""} 表示数据已经写入。

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,下面是TypeScript小白入门教程: 1. 安装TypeScript 首先,你需要安装TypeScript。你可以通过以下命令在全局安装TypeScript: ``` npm install -g typescript ``` 2. 创建一个TypeScript文件 创建一个新的文件,将其命名为`app.ts`。 在文件中,输入以下代码: ```typescript function greet(name: string) { console.log("Hello, " + name.toUpperCase() + "!!"); } greet("World"); ``` 3. 编译TypeScript文件 在命令行中进入到你的项目目录,并运行以下命令: ``` tsc app.ts ``` 这将编译你的TypeScript文件并生成一个JavaScript文件。 在此示例中,生成的JavaScript文件名为`app.js`。 4. 运行JavaScript文件 现在,你可以运行JavaScript文件。 在命令行中运行以下命令: ``` node app.js ``` 这将输出“Hello,WORLD!” 5. 定义变量类型 TypeScript需要在变量声明时指定其类型。 在下面的示例中,我们定义了一个名为`age`的变量,并将其类型设置为`number`: ```typescript let age: number = 25; ``` 6. 函数参数类型 与变量类似,TypeScript还需要在函数参数声明中指定类型。 在下面的示例中,我们定义了一个名为`greet`的函数,并将其参数的类型设置为`string`: ```typescript function greet(name: string) { console.log("Hello, " + name.toUpperCase() + "!!"); } greet("World"); ``` 7. 类型注释 TypeScript允许你使用类型注释来指定变量或函数的类型。 在下面的示例中,我们使用类型注释来指定变量`age`的类型: ```typescript let age: number; // age是一个数字类型的变量 ``` 8. 接口 接口是一种定义对象结构的方式。 在下面的示例中,我们定义了一个名为`Person`的接口,该接口具有两个属性:`name`和`age`: ```typescript interface Person { name: string; age: number; } let person: Person = { name: "John", age: 25 }; ``` 9. 类 类是一种定义对象的方式,可以具有属性和方法。 在下面的示例中,我们定义了一个名为`Person`的类,该类具有一个名为`name`的属性和一个名为`greet`的方法: ```typescript class Person { name: string; constructor(name: string) { this.name = name; } greet() { console.log("Hello, " + this.name + "!!"); } } let person = new Person("John"); person.greet(); ``` 这就是一个简单TypeScript入门教程。希望对你有所帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Jack_August

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

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

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

打赏作者

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

抵扣说明:

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

余额充值