”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > FiveM x TypeScript

FiveM x TypeScript

发布于2024-11-08
浏览:645

FiveM x TypeScript

FiveM 是 Grand Theft Auto V 的修改版,使您能够在由 Cfx.re 提供支持的定制专用服务器上玩多人游戏。

当您开发 FiveM 服务器时,您可以创建资源。这些资源可以用多种语言编写:Lua、C# 和 JavaScript。在本文中,我们将了解如何使用 TypeScript 构建资源

类型 :

为了输入代码,我们将使用 FiveM 背后的公司 CFX.re 提供的两个软件包

  • @citizenfx/客户
  • @citizenfx/服务器

这些包为客户端或服务器端代码中可用的每个本机方法提供了类型。

tsconfig.json

{
  "compilerOptions": {
    "target": "ES2020",
    "module": "ESNext",
    "moduleResolution": "Bundler",
    // Location
    "outDir": "./dist",
    // Other
    "types": ["@citizenfx/client", "@types/node"],
    "lib": ["ES2020"],
    "strict": true,
    "esModuleInterop": true,
    "allowSyntheticDefaultImports": true,
    "skipLibCheck": true
  },
  "include": ["src/**/*.ts"],
  "exclude": ["**/node_modules", "**/.test.ts"]
}

捆 :

编译 .ts 文件后,您必须创建一个将由 FiveM 服务器加载和运行的包。事实上,FiveM 只允许 require 原生 Node.js 包,如路径、fs、...

为此,我们使用名为 rollup 的工具,它是一个基于插件系统的 JavaScript 模块捆绑器。我也探索过其他工具,如 vite、rspack,但太复杂了。另一种提供良好性能的工具是turbopack,它是下一次捆绑之后的工具,但目前仍位于下一个内部。

rollup.config.mjs

import typescript from "@rollup/plugin-typescript";
import commonjs from "@rollup/plugin-commonjs";
import resolve from "@rollup/plugin-node-resolve";

export default {
  input: "src/index.ts",
  output: {
    dir: "dist",
    format: "cjs",
    sourcemap: false,
  },
  plugins: [resolve(), typescript(), commonjs()],
};

package.json :

{
  ...
  "devDependencies": {
    "@citizenfx/client": "2.0.9282-1",
    "@rollup/plugin-commonjs": "^26.0.1",
    "@rollup/plugin-node-resolve": "^15.2.3",
    "@rollup/plugin-typescript": "^11.1.6",
    "@types/node": "^20.14.12",
    "rollup": "^4.20.0",
    "tslib": "^2.6.3",
    "typescript": "^5.5.4"
  },
  ...
}

示例

init.ts

import { join } from "path"

export const init = () => {
    console.log("inited", join(".", "init.js"));
}

index.ts

import { init } from "./init"

on("onResourceStart", async (resName: string) => {
  if (resName === GetCurrentResourceName()) {
    init();
  }
});

运行 rollup -c 后,您将只有一个文件:

'use strict';

var path = require('path');

const init = () => {
    console.log("inited", path.join(".", "init.js"));
};

on("onResourceStart", async (resName) => {
    if (resName === GetCurrentResourceName()) {
        init();
    }
});

版本声明 本文转载于:https://dev.to/justinmartindev/fivem-x-typescript-3pgd?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 对于简单的操作,流总是比传统集合慢吗?
    对于简单的操作,流总是比传统集合慢吗?
    Java 8 流性能对比传统集合您最近涉足 Java 8 并进行了非正式基准测试,以将其 Stream API 与经典集合的性能进行比较。您的测试涉及过滤整数列表、提取偶数的平方根并将结果存储在 Double 列表中。然而,您质疑测试的有效性,并渴望澄清真正的性能影响。评估基准测试您的初步结果,表明...
    编程 发布于2024-11-08
  • 语言 API,允许您添加您的母语。
    语言 API,允许您添加您的母语。
    早在 2016 年 4 月,我就有了为一个我非常喜欢的部落“Igede Language”创建一个字典项目的想法,我决定将其称为“Igede Dictionary”,尽管我不是“ t 是母语人士。 这让我撰写并翻译了 5,000 多个单词,从 Igede 语言翻译成英语。毫无疑问,这是我曾经研究过...
    编程 发布于2024-11-08
  • 使用 Playwright、TypeScript 和 JavaScript 进行自动化
    使用 Playwright、TypeScript 和 JavaScript 进行自动化
    剧作家与 TypeScript | JavaScript 安装 Playwright 是 Microsoft 与 Puppeteer 团队合作推出的基于 Web 的现代 API 自动化工具,Puppeteer 是一个 JavaScript 库,它提供高级 API 来通过 DevTools 协议或 W...
    编程 发布于2024-11-08
  • 为什么使用 Z-Index 时我的伪元素出现在标题元素上方?
    为什么使用 Z-Index 时我的伪元素出现在标题元素上方?
    Z-Index 和伪元素:案例研究在 CSS 中,z-index 属性指定元素的堆叠顺序页面,确定哪些元素出现在其他元素“前面”或“后面”。然而,当涉及到伪元素时,例如 ::before 或 ::after,它们与 z-index 的交互有时可能不那么简单。考虑一个场景,我们使用::before 伪...
    编程 发布于2024-11-08
  • 如何在剥离标签之前删除顽固的 HTML 特殊字符?
    如何在剥离标签之前删除顽固的 HTML 特殊字符?
    去除顽固的 HTML 特殊字符strip_tags 函数虽然擅长删除 HTML 标签,但无法处理讨厌的 HTML 特殊字符,例如用于不间断空格或 © 用于版权符号。这可能是创建干净 RSS 源的绊脚石。要解决此问题,请考虑使用以下策略之一:HTML 实体解码:在字符串经过 strip_tags 之前...
    编程 发布于2024-11-08
  • 如何在 Go 中解密 AES ECB 模式加密?
    如何在 Go 中解密 AES ECB 模式加密?
    Go 中的 AES ECB 加密AES ECB 模式加密,其中每个明文块都独立加密,是一种简单但可能不安全的加密方法。在Go中,可以使用以下代码执行AES ECB解密:package main import ( "crypto/aes" "fmt&quo...
    编程 发布于2024-11-08
  • PHP 会话管理中的 session_unset() 和 session_destroy() 有什么区别?
    PHP 会话管理中的 session_unset() 和 session_destroy() 有什么区别?
    揭示 PHP 中 session_unset() 和 session_destroy() 的独特作用在 PHP 会话管理领域,出现了两个关键函数:session_unset() 和 session_destroy()。虽然它们似乎都围绕会话数据操作,但它们的功能和效果却显着不同。1。理解差异根据 P...
    编程 发布于2024-11-08
  • 以下是一些标题选项,请记住问题格式和文章的重点是控制选择框选项宽度:

**选项 1(更多技术性):**
* **如何控制Sele的宽度
    以下是一些标题选项,请记住问题格式和文章的重点是控制选择框选项宽度: **选项 1(更多技术性):** * **如何控制Sele的宽度
    如何控制选择框选项的宽度当选择框中的选项超出框的宽度时,可能会造成混乱以及笨拙的外观。为了解决这个问题,我们可以同时使用 CSS 和 JavaScript 来自定义选项的宽度并截断任何多余的文本。CSS 方法:虽然单独使用 CSS 是不行的足以设置选项的宽度,我们可以利用它来固定选择框本身的宽度。通...
    编程 发布于2024-11-08
  • C++ 异常说明符值得这么麻烦吗?
    C++ 异常说明符值得这么麻烦吗?
    C 中的异常说明符:你应该使用它们吗?C 中的异常说明符允许您指示函数是否可能抛出特定的异常类型。然而,由于担心 Visual Studio .NET 中的编译器执行、程序终止和非标准行为,人们对其实际用途产生了疑问。为什么不使用异常说明符:有限执行:编译器不严格执行异常说明符,从而减少了它们提供的...
    编程 发布于2024-11-08
  • 使用 .EJS 模板配置 Express
    使用 .EJS 模板配置 Express
    通常,我使用经典的入门版。 Expressjs.com const express = require('express') const app = express() const port = 3000 app.set('view engine', 'ejs') app.use(express.u...
    编程 发布于2024-11-08
  • 如何将自定义字体添加到 Tailwind - 对于网络和本地下载的字体
    如何将自定义字体添加到 Tailwind - 对于网络和本地下载的字体
    创建 Web 应用程序时,包含您喜欢的字体就像锦上添花。字体增强文本效果,使网站更具吸引力,并提供更好的用户体验。设计师和开发人员对某些字体又爱又恨,使用默认字体可能会限制他们的创造力。添加自定义字体使开发人员可以自由地将外部字体添加到他们的应用程序中。 先决条件 在本教程中,我强烈...
    编程 发布于2024-11-08
  • JavaScript 中柯里化的详细讨论
    JavaScript 中柯里化的详细讨论
    Currying হলো একটি ফাংশনাল প্রোগ্রামিং কৌশল যেখানে একটি ফাংশন একাধিক আর্গুমেন্ট নেওয়ার পরিবর্তে একটি একক আর্গুমেন্ট গ্রহণ করে এবং একটি নতুন ফাংশন রিটা...
    编程 发布于2024-11-08
  • 了解 Python 装饰器:深入探讨
    了解 Python 装饰器:深入探讨
    Python 装饰器是强大的工具,允许我们修改或增强函数或方法的行为。常见用例包括日志记录、授权等。 然而,当被要求定义一个装饰器时,许多人可能会说, 它是函数的包装器。 虽然这在技术上是正确的,但幕后还发生了更多事情。 剖析一个简单的装饰器 让我们探讨一个简单的例子: def my_decora...
    编程 发布于2024-11-08
  • 课程计划:年级学生 Python 基础知识(初级)
    课程计划:年级学生 Python 基础知识(初级)
    客观的: 在本课程结束时,学生将对 Python 编程有基本的了解,包括变量、基本数据类型、循环和函数。他们将使用 Python 创建简单的程序,运用逻辑思维和解决问题的技能。 持续时间:6 节课 第 1 课:Python 简介和设置 目标:让学生熟...
    编程 发布于2024-11-08
  • 如何在 Java 中正确复制二维数组以保留修改?
    如何在 Java 中正确复制二维数组以保留修改?
    通过复制保留二维数组修改在 Java 中,创建对象副本时,了解引用分配行为至关重要。在给定的场景中,定义了两个名为 current 和 old 的二维数组,以及复制内容的方法。old() 方法将 current 数组分配给 old 。然而,这只是将引用传输到内存中的同一数组。当对 current 进...
    编程 发布于2024-11-08

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3