IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vite-plugin-vue-setup-extend和unplugin-auto-import让v3开发更丝滑 -> 正文阅读

[JavaScript知识库]vite-plugin-vue-setup-extend和unplugin-auto-import让v3开发更丝滑

一.vite-plugin-vue-setup-extend让v3的setup语法糖增强

在使用setup语法糖的时候没办法直接为组件定义name,需要使用两个script标签来完成,如:

<script lang="ts">
import { defineComponent, onMounted } from 'vue'

//script1:用来定义name
export default defineComponent({
  name: '自定义name'
})
</script>

//script2:用来定义setup语法糖
<script lang="ts" setup>
onMounted(() => {
  console.log('===')
})
</script>

解决方案:

1.下载此插件:

npm i?vite-plugin-vue-setup-extend -D

?2.vite.config.js中:

import { defineConfig } from 'vite'
import vue from "@vitejs/plugin-vue";
import VueSetupExtend from 'vite-plugin-vue-setup-extend'

export default defineConfig({
  plugins: [
    vue(),
    VueSetupExtend()
  ]
})

3.使用:

<script lang="ts" setup name="自定义name">
import { onMounted } from 'vue'

onMounted(() => {
  console.log('===')
})
</script>

二、unplugin-auto-import让API自动导入

比如(这里建议大家对比较熟悉的api做引入咯):

可以让vueAPI里面的ref,reactive,watch,watchEffect等等api直接写在setup内,

可以让vue-router中的createRouter,createWebHashHistory,createWebHistory,useRoute,useRouter等API直接写在setup内

也可以让pinia中的createPinia,definStore直接写在setup内,都不需要再import导入了

1.安装插件:

npm i?unplugin-auto-import -D

?2.vite.config.js中:

import { defineConfig } from 'vite'
import vue from "@vitejs/plugin-vue";
import AutoImport from 'unplugin-auto-import/vite'

export default defineConfig({
  plugins: [
    vue(),
    AutoImport({
      // 后续vue/vue-router/pinia的API都不需要再单独import到setup里面了
      imports: [
            'vue',
            'vue-router',
            'pinia'
        ],
        //dts: 'src/auto-imports...', // 可以自定义文件生成的位置与是否生成,默认是根目录下
        dts: false
    })
  ]
})

?3.使用:

<script lang="ts" setup name="自定义name">
// onmounted属于vuede API不需要单独引入了
// import { onMounted } from 'vue'

onMounted(() => {
  console.log('===')
})
</script>

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-09-04 01:02:48  更:2022-09-04 01:04:42 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 13:02:09-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码