Rumah > hujung hadapan web > View.js > Cara menggunakan gula sintaks persediaan vue3

Cara menggunakan gula sintaks persediaan vue3

王林
Lepaskan: 2023-05-10 11:43:05
ke hadapan
1499 orang telah melayarinya

    1. Pengenalan kepada persediaan gula sintaks

    Anda boleh menggunakan tetapan gula sintaks dengan menambahkan atribut persediaan dalam teg skrip.

    Selepas menggunakan gula sintaks persediaan, tidak perlu menulis fungsi persediaan hanya perlu diperkenalkan dan tidak perlu didaftarkan dan kaedah tidak perlu dikembalikan dan boleh digunakan terus dalam template .

    	<template>
    		<my-component @click="func" :numb="numb"></my-component>
    	</template>
    	<script lang="ts" setup>
    		import {ref} from &#39;vue&#39;;
    		import myComponent from &#39;@/component/myComponent.vue&#39;;
    		//此时注册的变量或方法可以直接在template中使用而不需要导出
    		const numb = ref(0);
    		let func = ()=>{
    			numb.value++;
    		}
    	</script>
    Salin selepas log masuk

    2. Api baharu dalam persediaan gula sintaks

    • defineProps: komponen anak menerima prop daripada komponen induk

    • defineEmits: Komponen anak memanggil kaedah dalam komponen induk

    • defineExpose: Komponen anak mendedahkan sifat, yang boleh diperolehi dalam komponen induk

    2.1defineProps

    Kod komponen induk

    	<template>
    		<my-component @click="func" :numb="numb"></my-component>
    	</template>
    	<script lang="ts" setup>
    		import {ref} from &#39;vue&#39;;
    		import myComponent from &#39;@/components/myComponent.vue&#39;;
    		const numb = ref(0);
    		let func = ()=>{
    			numb.value++;
    		}
    	</script>
    Salin selepas log masuk

    Kod komponen kanak-kanak

    	<template>
    		<div>{{numb}}</div>
    	</template>
    	<script lang="ts" setup>
    		import {defineProps} from &#39;vue&#39;;
    		defineProps({
    			numb:{
    				type:Number,
    				default:NaN
    			}
    		})
    	</script>
    Salin selepas log masuk

    2.2defineEmits

    Kod komponen kanak-kanak

    	<template>
    		<div>{{numb}}</div>
    		<button @click="onClickButton">数值加1</button>
    	</template>
    	<script lang="ts" setup>
    		import {defineProps,defineEmits} from &#39;vue&#39;;
    		defineProps({
    			numb:{
    				type:Number,
    				default:NaN
    			}
    		})
    		const emit = defineEmits([&#39;addNumb&#39;]);
    		const onClickButton = ()=>{
    			//emit(父组件中的自定义方法,参数一,参数二,...)
    			emit("addNumb");
    		}
    	</script>
    Salin selepas log masuk

    Kod komponen induk

    	<template>
    		<my-component @addNumb="func" :numb="numb"></my-component>
    	</template>
    	<script lang="ts" setup>
    		import {ref} from &#39;vue&#39;;
    		import myComponent from &#39;@/components/myComponent.vue&#39;;
    		const numb = ref(0);
    		let func = ()=>{
    			numb.value++;
    		}
    	</script>
    Salin selepas log masuk

    2.3defineExpose

    Kod komponen kanak-kanak

    	<template>
    		<div>子组件中的值{{numb}}</div>
    		<button @click="onClickButton">数值加1</button>
    	</template>
    	<script lang="ts" setup>
    		import {ref,defineExpose} from &#39;vue&#39;;
    		let numb = ref(0);
    		function onClickButton(){
    			numb.value++;	
    		}
    		//暴露出子组件中的属性
    		defineExpose({
    			numb 
    		})
    	</script>
    Salin selepas log masuk

    Kod komponen induk

    	<template>
    		<my-comp ref="myComponent"></my-comp>
    		<button @click="onClickButton">获取子组件中暴露的值</button>
    	</template>
    	<script lang="ts" setup>
    		import {ref} from &#39;vue&#39;;
    		import myComp from &#39;@/components/myComponent.vue&#39;;
    		//注册ref,获取组件
    		const myComponent = ref();
    		function onClickButton(){
    			//在组件的value属性中获取暴露的值
    			console.log(myComponent.value.numb)  //0
    		}
    		//注意:在生命周期中使用或事件中使用都可以获取到值,
    		//但在setup中立即使用为undefined
    		console.log(myComponent.value.numb)  //undefined
    		const init = ()=>{
    			console.log(myComponent.value.numb)  //undefined
    		}
    		init()
    		onMounted(()=>{
    			console.log(myComponent.value.numb)  //0
    		})
    	</script>
    Salin selepas log masuk

    Tambahan: digunakan dengan skrip biasa

    biasa boleh digunakan dalam situasi di mana ini diperlukan.

    • Pilihan yang tidak boleh diisytiharkan dalam , seperti inheritAttrs atau pilihan tersuai yang didayakan melalui pemalam

    • Isytiharkan eksport bernama

    • Jalankan kesan sampingan atau cipta objek yang hanya perlu dilaksanakan sekali

    <script>
        // 普通 <script>, 在模块范围下执行(只执行一次)
        runSideEffectOnce()
        
        // 声明额外的选项
        export default {
          inheritAttrs: false,
          customOptions: {}
        }
    </script>
    
    <script setup>
        // 在 setup() 作用域中执行 (对每个实例皆如此)
    </script>
    Salin selepas log masuk

    Atas ialah kandungan terperinci Cara menggunakan gula sintaks persediaan vue3. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

    Label berkaitan:
    sumber:yisu.com
    Kenyataan Laman Web ini
    Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
    Tutorial Popular
    Lagi>
    Muat turun terkini
    Lagi>
    kesan web
    Kod sumber laman web
    Bahan laman web
    Templat hujung hadapan