setup语法糖:
一、Vue3.0 <script>里定义的变量、属性和方法必须 return 出来,<template>中才能使用;这样会导致在页面上变量会出现很多次。vue3.2只需在script标签中添加setup,就可以帮助我们解决这个问题,无需再写return了。
二、不用写export default 、setup函数
三、组件只需import引入不用写components{}注册
四、不可以直接写name: 'xxx', 但默认name 是 组件名,如Home.vue name 就是Home。
解决方案:
方式一: 如果想修改name可以再写一个script标签专门指定name
<script lang="ts">
export default {name: 'Home'
}
</script>
<script lang="ts" setup>
//
</script>
方式二: 使用defineOptions定义组件的name
<script lang="ts" setup>
import { defineOptions } from 'vue'
defineOptions({name: 'Home'
})
</script>
方式三:(vite版的项目)
1先安装npm i
vite-plugin-vue-setup-extend插件
2在vite.config.ts里配置 以下代码
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import vueSetupExtend from 'vite-plugin-vue-setup-extend'export default () => defineConfig({plugins: [vue(),// 配置vite-plugin-vue-setup-extend插件vueSetupExtend(),],
})
3.vue组件里修改name 再<script>标签上直接写 name="xxx组件name"就行了。
<script name="Home" lang="ts" setup>
</script>
五、新增 defineProps传参(父子组件间)通信 > 相当于接收props传参
六、新增defineEmits子组件向父组件抛出事件
七、新增defineExpose 子组件向父组件暴露属性 > 父组件通过ref可以获取到
八、新增内置指令 v-memo > v-memo=""等号里的值不发生变化,就不会进行更新视图。
九、v-bind 允许在css里绑定变量:
可以参考我的文章
https://www.toutiao.com/article/7302322534442451467/
Home/index.vue的代码:
<template><div class="home"><div>state.count : {{ state.count }}</div><div>state.msg : {{ state.msg }}</div><button @click="state.addCount">++state.Count</button><button @click="state.addChildAge">++子组件的clAge</button><br><!-- 子组件ChildA --><ChildAref="ChildARef":msg="state.msg":num-arr="[1,2,3,4,5]"@addMsg="state.addMsg"@clAddCount="state.clAddCount"/></div>
</template><!--方式1 如果想修改name可以再写一个script标签专门指定name -->
<!-- <script lang="ts">
export default {name: 'Home'
}
</script> --><!--方式3安装配置vite-plugin-vue-setup-extend插件后,直接在script标签中写name=""即可 -->
<script name="Home" lang="ts" setup>
import { ref, reactive, onMounted, defineOptions } from 'vue'// 方式2 定义组件的name
// defineOptions({
// name: 'Home'
// })
import ChildA from './ChildA.vue'
// vue3.2setup语法糖
const ChildARef: any = ref(null)
const state = reactive({count: 0,msg: 'hello world',addCount: () => {state.count++},//addMsg: (val) => {state.msg += val},clAddCount: (val) => {state.count += val},addChildAge: () => {ChildARef.value.clAge += 1},
})
onMounted(() => {//
})
</script><style lang="css" scoped>
.home {color: pink;font-size: 16px;
}
</style>
Home/ChildA.vue的代码:
<template><div style="font-size: 16px;background: rgb(77, 112, 228);"><h3>我是ChildA组件</h3><h3>测试传参</h3><div>props.msg:{{ msg }}</div><div>clAge:{{ clAge }}</div><!-- v-memo=""等号里的值不发生变化,就不会进行更新视图 --><div v-for="(item, index) in numArr" :key="index" v-memo="[numArr]">numArrItem:{{ item }}</div><button @click="handerAddMsg">新增msg</button><button @click="handerAddCount">新增count</button></div>
</template><script lang="ts" setup>
import { onMounted, defineProps, defineEmits, defineExpose, ref } from 'vue'
// vue3.2setup语法糖
const props = defineProps({msg: {type: String,default: 'default-msg'},numArr: {type: Array,default: () => []}
})
const $myDefineEmits = defineEmits(['addMsg', 'clAddCount'])
const handerAddMsg = ():void => {$myDefineEmits('addMsg', '新增msg->')
}
const handerAddCount = ():void => {$myDefineEmits('clAddCount', 1)
}
const clAge = ref(18)
defineExpose({clAge
})
onMounted(() => {console.log(props)
})
</script>
初始页面显示效果:
父组件index文件设置name="Home",可以看到组件变为Home。
子组件ChildA文件没设置name,可以看到组件名和组件相同ChildA。
点击++state.Count按钮页面显示效果:
点击++子组件的clAge按钮页面显示效果:
点击新增msg按钮页面显示效果:
点击新增count按钮页面显示效果:
可以看到父子组件间的通信是足够用的,新的方法使用起来和之前其实大同小异,代码还比之前简洁了。
欢迎关注我的原创文章:小伙伴们!我是一名热衷于前端开发的作者,致力于分享我的知识和经验,帮助其他学习前端的小伙伴们。在我的文章中,你将会找到大量关于前端开发的精彩内容。
学习前端技术是现代互联网时代中非常重要的一项技能。无论你是想成为一名专业的前端工程师,还是仅仅对前端开发感兴趣,我的文章将能为你提供宝贵的指导和知识。
在我的文章中,你将会学到如何使用HTML、CSS和JavaScript创建精美的网页。我将深入讲解每个语言的基础知识,并提供一些实用技巧和最佳实践。无论你是初学者还是有一定经验的开发者,我的文章都能够满足你的学习需求。
此外,我还会分享一些关于前端开发的最新动态和行业趋势。互联网技术在不断发展,新的框架和工具层出不穷。通过我的文章,你将会了解到最新的前端技术趋势,并了解如何应对这些变化。
我深知学习前端不易,因此我将尽力以简洁明了的方式解释复杂的概念,并提供一些易于理解的实例和案例。我希望我的文章能够帮助你更快地理解前端开发,并提升你的技能。
如果你想了解更多关于前端开发的内容,不妨关注我的原创文章。我会不定期更新,为你带来最新的前端技术和知识。感谢你的关注和支持,我们一起探讨交流技术共同进步,期待与你一同探索前端开发的奇妙世界!