AVt天堂网 手机版,亚洲va久久久噜噜噜久久4399,天天综合亚洲色在线精品,亚洲一级Av无码毛片久久精品

當(dāng)前位置:首頁(yè) > 科技  > 軟件

體驗(yàn)超現(xiàn)代的 Vue ?Vue Macros 使用探索

來(lái)源: 責(zé)編: 時(shí)間:2024-05-23 17:09:27 144觀看
導(dǎo)讀什么是 Vue MacrosVue Macros 是一個(gè) vue 的周邊庫(kù),可以在 Vue 2.7 以上的項(xiàng)目中進(jìn)行使用。并引入了一套高級(jí)功能(宏)和語(yǔ)法糖。圖片這些宏是庫(kù)的一部分,主要是實(shí)現(xiàn)了 Vue 目前尚未正式采用的提案。如何使用?要開始在項(xiàng)目

什么是 Vue Macros

Vue Macros 是一個(gè) vue 的周邊庫(kù),可以在 Vue 2.7 以上的項(xiàng)目中進(jìn)行使用。并引入了一套高級(jí)功能(宏)和語(yǔ)法糖。yMq28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片yMq28資訊網(wǎng)——每日最新資訊28at.com

這些宏是庫(kù)的一部分,主要是實(shí)現(xiàn)了 Vue 目前尚未正式采用的提案。yMq28資訊網(wǎng)——每日最新資訊28at.com

如何使用?

要開始在項(xiàng)目中使用 Vue Macros,首先需要安裝該庫(kù):yMq28資訊網(wǎng)——每日最新資訊28at.com

使用 npm:npm install -D unplugin-vue-macros使用 yarn:yarn add -D unplugin-vue-macros使用 pnpm:pnpm add -D unplugin-vue-macros

安裝后,需要打包器進(jìn)行不同的配置。yMq28資訊網(wǎng)——每日最新資訊28at.com

如果使用 Vite ,則需要在 vite.config.js 文件中:yMq28資訊網(wǎng)——每日最新資訊28at.com

import { defineConfig } from "vite";import VueMacros from "unplugin-vue-macros/vite";import Vue from "@vitejs/plugin-vue";export default defineConfig({  plugins: [    VueMacros({      plugins: {        vue: Vue(),      },    }),  ],});

對(duì)于 TypeScript 項(xiàng)目,tsconfig.json需要進(jìn)行額外配置:yMq28資訊網(wǎng)——每日最新資訊28at.com

{  "compilerOptions": {    "types": ["unplugin-vue-macros/macros-global"]  }}

核心 API

defineOptions(Vue 3.3 默認(rèn)支持了該功能)

defineOptions允許直接在內(nèi)部聲明組件選項(xiàng)<script setup>,而不需要單獨(dú)的<script>塊,也就是說(shuō)可以在一個(gè)宏函數(shù)中設(shè)置 name, props, emits, render。yMq28資訊網(wǎng)——每日最新資訊28at.com

對(duì)于喜歡組合 API 但仍想使用某些選項(xiàng) API 功能的開發(fā)人員來(lái)說(shuō),這個(gè)宏非常有用。yMq28資訊網(wǎng)——每日最新資訊28at.com

<script setup lang='ts'>defineOptions({  name: "SearchComp",});</script>

defineSlots(Vue 3.3 默認(rèn)支持了該功能)

使用 defineSlots 可以在 <script setup> 中聲明 SFC 中插槽的類型yMq28資訊網(wǎng)——每日最新資訊28at.com

<script setup lang="ts">defineSlots<{  // 插槽名稱  title: {    // 作用域插槽    foo: 'bar' | boolean  }}>()</script>

defineProps

使用 $defineProps 可以正確地解構(gòu) props 的類型yMq28資訊網(wǎng)——每日最新資訊28at.com

<script setup lang="ts">//       ?? ReactiveVariable<string[]>const { foo } = $defineProps<{  foo: string[]}>()//     ?? Ref<string[]>const fooRef = $$(foo)</script>

definePropsRefs

從 defineProps 中將返回 refs 而不是 reactive 對(duì)象,可以在不丟失響應(yīng)式的情況下解構(gòu) props。yMq28資訊網(wǎng)——每日最新資訊28at.com

<script setup lang="ts">// ? 解構(gòu)不丟失響應(yīng)式const { foo, bar } = definePropsRefs<{  foo: string  bar: number}>()//          ?? Ref<string>console.log(foo.value, bar.value)</script>

defineRender

使用 defineRender 可以直接在 <script setup> 中定義渲染函數(shù)。yMq28資訊網(wǎng)——每日最新資訊28at.com

<script setup lang="tsx">// 可以直接傳遞 JSXdefineRender(  <div>    <span>Hello</span>  </div>,)// 或使用渲染函數(shù)defineRender(() => {  return (    <div>      <h1>Hello World</h1>    </div>  )})</script>

shortVmodel

v-model 的語(yǔ)法糖。直接通過(guò)特定符號(hào)('::' | '$' | '*')代替 v-model。默認(rèn)使用 $ 符號(hào)yMq28資訊網(wǎng)——每日最新資訊28at.com

<template>  <input $="msg" />  <!-- => <input v-model="msg" /> -->  <demo $msg="msg" />  <!-- => <input v-model:msg="msg" /> --></template>

總結(jié)

除此之外,Vue Macros 還提供了很多其他的宏或 語(yǔ)法糖 可供大家使用。但是需要注意的是,目前有些 實(shí)驗(yàn)性質(zhì) 的功能需要注意謹(jǐn)慎使用。yMq28資訊網(wǎng)——每日最新資訊28at.com


yMq28資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://www.tebozhan.com/showinfo-26-90339-0.html體驗(yàn)超現(xiàn)代的 Vue ?Vue Macros 使用探索

聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。郵件:2376512515@qq.com

上一篇: yolov部署到iPhone或終端實(shí)踐全過(guò)程

下一篇: 一文搞懂七種基本的GC垃圾回收算法

標(biāo)簽:
  • 熱門焦點(diǎn)
Top