您的位置: 翼速应用 > 业内知识 > PHP框架 > 正文

一起聊聊在Laravel中如何用Typescript

越来越多的Laravel 开发人员已经开始编写更强类型的代码,而全栈开发人员往往不会将相同的实践应用于他们的前端代码。其中,TypeScript 被认为是编写前端组件的一种不同的方式。本文和大家一起聊一下在Laravel中如何用Typescript的内容,希望能够帮助到大家。


 一起聊聊在Laravel中如何用Typescript


一起聊聊在Laravel中如何用Typescript


大多数人对 TypeScript 的误解,就是认为它对后端开发人员来说太复杂了,而且只会膨胀代码规模,而没有提供任何额外的价值。实际上,TypeScript 并不强制你声明类型。这是重要的部分:TypeScript 是一个 JavaScript 超集,可以让你在上面添加东西,但是任何有效的 JS 也是有效的 TS。这样做的实际影响是,你可以将文件从 .js 重命名为 .ts,并逐渐添加类型或开始在新文件中使用类型。你的代码库不必达到 100% 的类型覆盖率。你可以根据自己的选择使用 TypeScript。


下面让我们用 Vue 3 重新安装 Laravel Breeze 来回顾一下:


1. 安装依赖


让我们从安装 TypeScript 编译器和相应的 Webpack 加载器开始。


npm install ts-loader typescript --save-dev
# 或者
yarn add ts-loader typescript -D


2. 设置 TypeScript 配置


TypeScript 编译器需要一个包含所需选项的配置文件。适当的 IDE 自动完成也是可取的。


tsconfig.json


{
  "compilerOptions": {
    "target": "es5",
    "module": "es2020",
    "moduleResolution": "node",
    "baseUrl": "./",
    "strict": true,                 // Enable strict type-checking options
    "skipLibCheck": true,           // Skip type checking of declaration files
    "noImplicitAny": false          // Bypass raising errors on `any` type
  },
  "include": ["resources/js/**/*"]  // 前端路径模式
}


3. 配置 Laravel Mix


初始 Laravel 安装带有一个 JavaScript 入口示例,需要将其转换为 TypeScript。您只需将 .js 重命名为 .ts。


-resources/js/app.js
+resources/js/app.ts


然后,让 Mix 知道它应该将 JavaScript 代码作为 TypeScript 处理。 Laravel Mix 带有内置的 TypeScript 支持。


webpack.mix.js


-mix.js('resources/js/app.js', 'public/js')
+mix.ts('resources/js/app.ts', 'public/js')


你还需要告诉编译器和 IDE,组件的代码必须被视为 TypeScript。将 部分附加到组件脚本部分。


<script>
import { defineComponent } from "@vue/runtime-core";
 
export default defineComponent({
    ...
});
</script>


你可以继续按照以前的方式编写代码,并利用一些 TypeScript 功能并改善你的前端体验。


示例用法


TypeScript 允许你使用简单类型和复杂结构来类型提示变量和方法。由于我们主要关注与后端交互,让我们看一下与模型交互的示例。


让我们创建一个包含所有必要类型声明的文件 —— resources/js/types.d.ts。


假设你有一个模型用户,你可以从前端与之交互。这是默认用户模型的基本 TypeScript 表示。它描述了一个对象可以具有哪些属性以及这些属性应该是什么类型。


resources/js/types.d.js


declare interface User {
    id: number;
    name: string;
    email: string;
}


现在,你可以在分配变量或从方法返回值时使用此接口。


let user = <User>{ id: 1, name: 'Taylor Otwell' }
 
function getUser(): User {
    ...
}


因此,当你访问 user 变量时,你的 IDE 会建议相应的对象属性。它还会在你编译代码之前让你知道何时出现类型错误。


为所有模型编写接口并使其与后端代码保持同步需要额外的时间。你可能需要考虑使用 laravel-typescript 扩展,它可以让你将 Laravel 模型转换为 TypeScript 声明,并使它们与你的迁移保持同步。


关于在Laravel中如何用Typescript的详细解析到这里就结束了,翼速应用平台内有更多相关资讯,欢迎查阅!


我来说两句

0 条评论

推荐阅读

  • 响应式布局CSS媒体查询设备像素比介绍

    构建响应式网站布局最常见的是流体网格,灵活调整大小的站点布局技术,确保用户在使用的幕上获得完整的体验。响应式设计如何展示富媒体图像,可以通过以下几种方法。

    admin
  • 提升网站的性能快速加载的实用技巧

    网站速度很重要,快速加载的网站会带来更好的用户体验、更高的转化率、更多的参与度,而且在搜索引擎排名中也扮演重要角色,做SEO,网站硬件是起跑线,如果输在了起跑线,又怎么跟同行竞争。有许多方法可提升网站的性能,有一些技巧可以避免踩坑。

    admin
  • 织梦CMS TAG页找不到标签和实现彩色标签解决方法

    织梦cms是我们常见的网站程序系统的一款,在TAG标签中常常遇到的问题也很多。当我们点击 tags.php 页的某个标签的时候,有时会提示:“系统无此标签,可 能已经移除!” 但是我们检查程序后台,以及前台显示页面。这个标签确实存在,如果解决这个问题那?

    admin
  • HTML关于fieldset标签主要的作用

    在前端开发html页面中常用的标签很多,今天为大家带来的是关于HTML中fieldset标签主要的作用说明,根据技术分析HTML

    admin

精选专题