91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在Vue3中使用<script?lang=“ts“?setup>語法糖

發布時間:2022-06-13 17:12:53 來源:億速云 閱讀:2293 作者:iii 欄目:開發技術

這篇文章主要介紹“怎么在Vue3中使用<script lang=“ts“ setup>語法糖”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“怎么在Vue3中使用<script lang=“ts“ setup>語法糖”文章能幫助大家解決問題。

遷移組件

以下組件有兩個道具(要顯示的和一個標志)。基于這兩個道具,計算模板中顯示的小馬圖像的URL(通過另一個組件)。該組件還會在用戶單擊它時發出一個事件。PonyponyModelisRunningImageselected

Pony.vue

<template>
  <figure @click="clicked()">
    <Image :src="ponyImageUrl" :alt="ponyModel.name" />
    <figcaption>{{ ponyModel.name }}</figcaption>
  </figure>
</template>
<script lang="ts">
import { computed, defineComponent, PropType } from 'vue';
import Image from './Image.vue';
import { PonyModel } from '@/models/PonyModel';
 
export default defineComponent({
  components: { Image },
 
  props: {
    ponyModel: {
      type: Object as PropType<PonyModel>,
      required: true
    },
    isRunning: {
      type: Boolean,
      default: false
    }
  },
 
  emits: {
    selected: () => true
  },
 
  setup(props, { emit }) {
    const ponyImageUrl = computed(() => `/pony-${props.ponyModel.color}${props.isRunning ? '-running' : ''}.gif`);
 
    function clicked() {
      emit('selected');
    }
 
    return { ponyImageUrl, clicked };
  }
});
</script>

第一步,將屬性添加到元素中。然后,我們只需要保留函數的內容:所有的樣板都可以消失。您可以刪除 和 中的函數:setupscriptsetupdefineComponentsetupscript

Pony.vue

<script setup lang="ts">
import { computed, PropType } from 'vue';
import Image from './Image.vue';
import { PonyModel } from '@/models/PonyModel';
 
components: { Image },
 
props: {
  ponyModel: {
    type: Object as PropType<PonyModel>,
    required: true
  },
  isRunning: {
    type: Boolean,
    default: false
  }
},
 
emits: {
  selected: () => true
},
 
const ponyImageUrl = computed(() => `/pony-${props.ponyModel.color}${props.isRunning ? '-running' : ''}.gif`);
 
function clicked() {
  emit('selected');
}
 
return { ponyImageUrl, clicked };
</script>

隱式返回

我們還可以刪除末尾的:在模板中聲明的所有頂級綁定(以及所有導入)都自動可用。所以這里和可用,無需返回它們。returnscript setupponyImageUrlclicked

聲明也是如此!導入組件就足夠了,Vue 知道它在模板中使用:我們可以刪除聲明。componentsImagecomponents

Pony.vue

<script setup lang="ts">
import { computed, PropType } from 'vue';
import Image from './Image.vue';
import { PonyModel } from '@/models/PonyModel';
 
props: {
  ponyModel: {
    type: Object as PropType<PonyModel>,
    required: true
  },
  isRunning: {
    type: Boolean,
    default: false
  }
},
 
emits: {
  selected: () => true
},
 
const ponyImageUrl = computed(() => `/pony-${props.ponyModel.color}${props.isRunning ? '-running' : ''}.gif`);
 
function clicked() {
  emit('selected');
}
</script>

我們差不多做到了:我們現在需要遷移 和 聲明。propsemits

defineProps

Vue 提供了一個助手,你可以用它來定義你的道具。它是一個編譯時幫助程序(一個宏),所以你不需要在代碼中導入它:Vue 在編譯組件時會自動理解它。defineProps

defineProps返回道具:

const props = defineProps({
  ponyModel: {
    type: Object as PropType<PonyModel>,
    required: true
  },
  isRunning: {
    type: Boolean,
    default: false
  }
});

defineProps將前一個聲明作為參數接收。但是我們可以為TypeScript用戶做得更好!props

defineProps是一般類型化的:你可以在沒有參數的情況下調用它,但指定一個接口作為道具的“形狀”。沒有更可怕的寫!我們可以使用正確的 TypeScript 類型,并添加以將 prop 標記為不需要 ???? 。Object as PropType<Something>?

const props = defineProps<{
  ponyModel: PonyModel;
  isRunning?: boolean;
}>();

不過我們丟失了一些信息。在以前的版本中,我們可以指定其默認值為 .為了具有相同的行為,我們可以使用幫助程序:isRunningfalsewithDefaults

interface Props {
  ponyModel: PonyModel;
  isRunning?: boolean;
}
 
const props = withDefaults(defineProps<Props>(), { isRunning: false });

要遷移的最后一個剩余語法是聲明。emits

defineEmits

Vue 提供了一個幫助程序,與幫助程序非常相似。 返回函數:defineEmitsdefinePropsdefineEmitsemit

const emit = defineEmits({
  selected: () => true
});

或者更好的是,使用TypeScript:

const emit = defineEmits<{
  (e: 'selected'): void;
}>();

完整組件聲明縮短了 10 行。對于~30行組件來說,這不是一個糟糕的減少!它更容易閱讀,并且與TypeScript配合得更好。讓所有內容自動暴露到模板中確實感覺有點奇怪,但是沒有寫回車符,但是您已經習慣了。

Pony.vue

<template>
  <figure @click="clicked()">
    <Image :src="ponyImageUrl" :alt="ponyModel.name" />
    <figcaption>{{ ponyModel.name }}</figcaption>
  </figure>
</template>
 
<script setup lang="ts">
import { computed } from 'vue';
import Image from './Image.vue';
import { PonyModel } from '@/models/PonyModel';
 
interface Props {
  ponyModel: PonyModel;
  isRunning?: boolean;
}
 
const props = withDefaults(defineProps<Props>(), { isRunning: false });
 
const emit = defineEmits<{
  (e: 'selected'): void;
}>();
 
const ponyImageUrl = computed(() => `/pony-${props.ponyModel.color}${props.isRunning ? '-running' : ''}.gif`);
 
function clicked() {
  emit('selected');
}
</script>

默認關閉和defineExpose

聲明組件的兩種方法之間有一個更細微的區別:組件是“默認關閉的”。這意味著其他組件看不到組件內部定義的內容。script setup

例如,組件可以訪問該組件(通過使用 refs,我們將在下一章中看到)。如果定義為 ,則函數返回的所有內容對于父組件 () 也是可見的。如果 用 定義,則父組件不可見。 可以通過添加助手來選擇暴露的內容。然后,公開的將作為 訪問。PonyImageImagedefineComponentsetupPonyImagescript setupImagedefineExpose({ key: value })valuekey

關于“怎么在Vue3中使用<script lang=“ts“ setup>語法糖”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

团风县| 临洮县| 湛江市| 新干县| 刚察县| 日喀则市| 武川县| 兴山县| 江安县| 礼泉县| 若尔盖县| 凤翔县| 鄄城县| 卓资县| 陕西省| 穆棱市| 商南县| 肇源县| 双桥区| 枣强县| 阳信县| 民丰县| 沙河市| 公安县| 小金县| 曲周县| 南开区| 泰兴市| 五指山市| 库伦旗| 涡阳县| 上蔡县| 青州市| 抚远县| 宝清县| 普陀区| 育儿| 涪陵区| 义马市| 阜新| 平武县|