热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Vite+Vue2+Compositionapi+scriptsetup+TypeScript搭配如何开发项目?

前言Vite相信大家都用过,它是一种新型前端开发与构建工具,能够显著提升前端开发体验。我们在搭建Vite项目,选择Vue模板之后ÿ

前言

Vite相信大家都用过,它是一种新型前端开发与构建工具,能够显著提升前端开发体验。我们在搭建Vite项目,选择Vue模板之后,默认会下载Vue3模板。如果你的公司现在还没有准备使用Vue3,而在使用Vue2,那么这篇文章值得你继续看下去。下面,我将带大家如何搭建一个 Vite+Vue2+Composition-api+

package.json

这个文件定义了这个项目所需要的各种模块,以及项目的配置信息(比如名称、版本、许可证等元数据)。这里,需要注意的是我们自定义了"scripts"字段,有三个命令:"vite --open""vite preview""vite build"

{"name": "vitevue2p","version": "0.1.1","description": "","keywords": [],"license": "MIT","main": "dist/index.js","module": "dist/index.mjs","scripts": {"dev": "vite --open","serve": "vite preview","build": "vite build"},"dependencies": {"@vue/composition-api": "^1.1.5","vue": "^2.6.14"},"devDependencies": {"@vue/runtime-dom": "3.2.11","typescript": "^4.4.3","unplugin-vue2-script-setup": "^0.6.4","vite": "^2.5.7","vite-plugin-vue2": "^1.8.1","vue-template-compiler": "^2.6.14"}
}

ref-macros.d.ts

d.ts后缀结尾的是TypeScript中的类型定义文件。我们知道自从引入 Composition API 以来,一个主要未解决的问题是 refsreactive的使用,到处使用 .value可能很麻烦,如果不使用类型系统,很容易错过。一些用户特别倾向于只使用reactive,这样他们就不必处理refs

为了优化,官方提出了一个RFC,大家可以打开下面这个网址 https://github.com/vuejs/rfcs/discussions/369 了解一下。

下面,可以看下一个简单的例子。

// declaring a reactive variable backed by an underlying ref
let count = $ref(1)// no need for .value anymore!
console.log(count) // 1function inc() {// assignments are reactivecount++
}

另外,这是一项实验性功能。实验性功能可能会改变补丁版本之间的行为。建议将您的 vue 依赖项固定到确切的版本以避免损坏。

言归正传,我们来看下ref-macros.d.ts文件中的内容。

import type {Ref,UnwrapRef,ComputedRef,WritableComputedOptions,WritableComputedRef,ShallowUnwrapRef,
} from '@vue/composition-api'declare const RefMarker: unique symboltype RefValue = T & { [RefMarker]?: any }declare const ComputedRefMarker: unique symboltype ComputedRefValue = T & { [ComputedRefMarker]?: any }declare const WritableComputedRefMarker: unique symboltype WritableComputedRefValue = T & { [WritableComputedRefMarker]?: any }type ToRawRefs = {[K in keyof T]: T[K] extends ComputedRefValue? ComputedRefValue: T[K] extends WritableComputedRefValue? WritableComputedRef: T[K] extends RefValue? Ref: T[K] extends object? T[K] extends| Function| Map| Set| WeakMap| WeakSet? T[K]: ToRawRefs: T[K];}/*** Vue ref transform macro for binding refs as reactive variables.*/
declare function _$(arg: ComputedRef): ComputedRefValue
declare function _$(arg: WritableComputedRef
): WritableComputedRefValue
declare function _$(arg: Ref): RefValue
declare function _$(arg?: T): ShallowUnwrapRef/*** Vue ref transform macro for accessing underlying refs of reactive varaibles.*/
declare function _$$(value: T): ComputedRef
declare function _$$(value: WritableComputedRefValue
): WritableComputedRef
declare function _$$(value: RefValue): Ref
declare function _$$(arg: T): ToRawRefsdeclare function _$ref(arg?: T | Ref): RefValue>declare function _$shallowRef(arg?: T): RefValuedeclare function _$computed(getter: () => T,// debuggerOptions?: DebuggerOptions
): ComputedRefValue
declare function _$computed(options: WritableComputedOptions,// debuggerOptions?: DebuggerOptions
): WritableComputedRefValuedeclare global {const $: typeof _$const $$: typeof _$$const $ref: typeof _$refconst $shallowRef: typeof _$shallowRefconst $computed: typeof _$computed
}

tsconfig.json

tsconfig.json文件中指定了用来编译这个项目的根文件和编译选项。

我们这里需要注意如果您的 IDE 缺少全局类型。

{"compilerOptions": {"types": ["unplugin-vue2-script-setup/types"]}
}

Volar 优先支持 Vue 3。Vue 3 和 Vue 2 模板有些不同。您需要设置 ExperimentCompatMode 选项以支持 Vue 2 模板。

{"compilerOptions": {...},"vueCompilerOptions": {"experimentalCompatMode": 2},
}

最后,文件内容如下:

{"compilerOptions": {"target": "es2017","module": "esnext","moduleResolution": "node","esModuleInterop": true,"strict": true,"strictNullChecks": true,"resolveJsonModule": true,"types": ["unplugin-vue2-script-setup/types"]},"vueCompilerOptions": {"experimentalCompatMode": 2}
}

vite.config.ts

这个文件是Vite的配置文件。当以命令行方式运行 vite 时,Vite 会自动解析项目根目录下名为 vite.config.js(或vite.config.ts) 的文件。

这里需要注意 refTransform 现在是插件根级选项,需要手动定义为true。(为什么配置refTransform,可以看上面ref-macros.d.ts文件中对refs处理,不使用.value的介绍)。

另外,如果想支持

HelloWorld.vue

然后,我们再看下这个文件中什么内容。这里需要注意的是$ref()$computed()方法,这就是之前提到的refTransform语法,不得不说,这比以前使用.value处理方便多了。


其他文件就不过多介绍了,就只是简单的模板文件。

Foo.vue

Bar.vue

Async.vue

结语

最后,我们启动下项目。

yarn dev

c049db57f0e459657b4151c57586ae2e.png

如上图所示,启动成功。

相信这样可以在一定程度上提升你 Vue 2 的开发体验,赶快来!

以下是本篇文章的源码地址:

https://github.com/maomincoding/viteVue2p


推荐阅读
  • 使用在线工具jsonschema2pojo根据json生成java对象
    本文介绍了使用在线工具jsonschema2pojo根据json生成java对象的方法。通过该工具,用户只需将json字符串复制到输入框中,即可自动将其转换成java对象。该工具还能解析列表式的json数据,并将嵌套在内层的对象也解析出来。本文以请求github的api为例,展示了使用该工具的步骤和效果。 ... [详细]
  • Android实战——jsoup实现网络爬虫,糗事百科项目的起步
    本文介绍了Android实战中使用jsoup实现网络爬虫的方法,以糗事百科项目为例。对于初学者来说,数据源的缺乏是做项目的最大烦恼之一。本文讲述了如何使用网络爬虫获取数据,并以糗事百科作为练手项目。同时,提到了使用jsoup需要结合前端基础知识,以及如果学过JS的话可以更轻松地使用该框架。 ... [详细]
  • 在package.json中有如下两个对象:husky:{hooks:{pre-commit:lint-staged}},lint-staged:{src** ... [详细]
  • 本文介绍了自学Vue的第01天的内容,包括学习目标、学习资料的收集和学习方法的选择。作者解释了为什么要学习Vue以及选择Vue的原因,包括完善的中文文档、较低的学习曲线、使用人数众多等。作者还列举了自己选择的学习资料,包括全新vue2.5核心技术全方位讲解+实战精讲教程、全新vue2.5项目实战全家桶单页面仿京东电商等。最后,作者提出了学习方法,包括简单的入门课程和实战课程。 ... [详细]
  • Allegro总结:1.防焊层(SolderMask):又称绿油层,PCB非布线层,用于制成丝网印板,将不需要焊接的地方涂上防焊剂.在防焊层上预留的焊盘大小要比实际的焊盘大一些,其差值一般 ... [详细]
  • Vue3 拥抱 TypeScript 的完整项目结构搭建
    大厂技术高级前端Node进阶点击上方程序员成长指北,关注公众号回复1,加入高级Node交流群一个完整的Vue3Ts项目,支持.vue和.tsx写法项目地 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Go Cobra命令行工具入门教程
    本文介绍了Go语言实现的命令行工具Cobra的基本概念、安装方法和入门实践。Cobra被广泛应用于各种项目中,如Kubernetes、Hugo和Github CLI等。通过使用Cobra,我们可以快速创建命令行工具,适用于写测试脚本和各种服务的Admin CLI。文章还通过一个简单的demo演示了Cobra的使用方法。 ... [详细]
  • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
  • Gitlab接入公司内部单点登录的安装和配置教程
    本文介绍了如何将公司内部的Gitlab系统接入单点登录服务,并提供了安装和配置的详细教程。通过使用oauth2协议,将原有的各子系统的独立登录统一迁移至单点登录。文章包括Gitlab的安装环境、版本号、编辑配置文件的步骤,并解决了在迁移过程中可能遇到的问题。 ... [详细]
  • 一、路由首先需要配置路由,就是点击good组件进入goodDetail组件配置路由如下{path:goodDetail,component:goodDetail}同时在good组件中写入如下点击事件,路由中加入 ... [详细]
  • Vue基础一、什么是Vue1.1概念Vue(读音vjuː,类似于view)是一套用于构建用户界面的渐进式JavaScript框架,与其它大型框架不 ... [详细]
  • 《从零构建前后星散的web项目》:前端相识过关了吗?
    #前端基本架构和硬核引见手艺栈的挑选起首我们构建前端架构须要对前端生态圈有统统相识,而且最好带有肯定的手艺前瞻性,好的手艺架构能够日后会轻易的扩大,削减重构的次数,纵然重构也不须要 ... [详细]
  • 业务:Payments&Risk大数据/AI/数据可视化时间要求:至少实习6个月,每周5天,入职时间4-5月 ... [详细]
author-avatar
风云再起2012668
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有