iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Vue3如何使用setup语法糖拒绝写return
  • 701
分享到

Vue3如何使用setup语法糖拒绝写return

2023-07-06 10:07:06 701人浏览 薄情痞子
摘要

这篇“vue3如何使用setup语法糖拒绝写return”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue3如何使用set

这篇“vue3如何使用setup语法糖拒绝写return”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue3如何使用setup语法糖拒绝写return”文章吧。

    Vue3.2 setup语法糖

    <script setup> 是在单文件组件 (SFC) 中使用组合式 api 的编译时语法糖

    解决Vue3.0中setup需要繁琐将声明的变量、函数以及 import 引入的内容通过return向外暴露,才能在<template/>使用的问题

    1.<script setup>在<template/>使用

    <script setup>中无需return 声明的变量、函数以及import引入的内容,即可在<template/>使用

    <script setup>语法糖

    <script setup>//import引入的内容import { getToday } from './utils'  // 变量const msg = 'Hello!'// 函数function log() {  console.log(msg)}</script>//在template中直接使用声明的变量、函数以及import引入的内容<template>  <div @click="log">{{ msg }}</div>   <p>{{getToday()}}</p></template>

    标准组件<script> 需要写setup函数并繁琐retrun

    <script>//import引入的内容import { getToday } from './utils'  export default{ setup(){    // 变量    const msg = 'Hello!'    // 函数    function log() {      console.log(msg)    }    //想在tempate里面使用需要在setup内return暴露出来    return{       msg,       log,       getToday     } }}</script><template>  <div @click="log">{{ msg }}</div>   <p>{{getToday()}}</p></template>

    小结:<script setup>语法糖里面的代码会被编译成组件 setup() 函数的内容,不需要通过return暴露 声明的变量、函数以及import引入的内容,即可在<template/>使用,并且不需要写export default{}

    <script setup>语法糖里面的代码会被编译成组件 setup() 函数的内容。这意味着与普通的 <script> 只在组件被首次引入的时候执行一次不同,<script setup> 中的代码会在每次组件实例被创建的时候执行

      <script>  console.log('script');//多次实例组件,只触发一次  export default {      setup() {          console.log('setupFn');//每次实例化组件都触发和script-setup标签一样      }  }  </script>

    (script-setup标签最终都会编译成setup() 函数的内容,每次实例化组件,就是实例化一次setup函数。script标签里面的setup函数也是一样每次实例化组件,就是实例化一次setup函数,但是script标签setup是需要写在export default{}内的,外的只是首次引入的时候执行一次)

    2、<script setup>引入组件将自动注册

    不需要在引入组件后,通过 components:{}注册组件,可直接使用

    &lt;script setup&gt;import MyComponent from './MyComponent.vue'//components:{MyComponent}  不需要注册直接使用&lt;/script&gt;&lt;template&gt; &nbsp;&lt;MyComponent /&gt;&lt;/template&gt;
    3、组件通信:

    <script setup>中必须使用 defineProps defineEmits API 来替代 props 和 emits

    definePropsdefineEmits具备完整的类型推断并且在 <script setup> 中是直接可用的(浏览了一下掘金,发现大部分文章demo还是通过import引入这2个api,这点官方文档写得很清楚)

    defineProps 代替props

    接收父组件传递的数据(父组件向子组件传参)

    父组件:

    <template>  <div>父组件</div>  <Child :title="msg" /></template><script setup>import {ref} from 'vue'import Child from './child.vue'const msg = ref('父的值')  //自动返回,在template直接解套使用</script>

    子组件:

    <template/> 中可以直接使用父组件传递的props (可省略props.)

    <script-setup> 需要通过props.xx获取父组件传递过来的props

    <template>  <div>子组件</div>  <div>父组件传递的值:{{title}}</div></template><script setup>//import {defineProps} from 'vue'   不需要引入//语法糖必须使用defineProps替代propsconst  props = defineProps({  title: {    type: String  }});//script-setup 需要通过props.xx获取父组件传递过来的propsconsole.log(props.title) //父的值</script>
    defineEmit 代替emit

    子组件向父组件传递数据(子组件向外暴露数据)

    子组件代码:

    <template>  <div>子组件</div>  <button @click="toEmits">子组件向外暴露数据</button></template><script setup>import {ref} from 'vue'const name = ref('我是子组件')//1、暴露内部数据const  emits = defineEmits(['childFn']);const  toEmits = () => {  //2、触发父组件中暴露的childFn方法并携带数据  emits('childFn',name)}</script>

    父组件代码:

    <template>  <div>父组件</div>  <Child  @childFn='childFn' />  <p>接收子组件传递的数据{{childData}} </p></template><script setup>import {ref} from 'vue'import Child from './child.vue'    const childData = ref(null)    const childFn=(e)=>{    consloe.log('子组件触发了父组件childFn,并传递了参数e')    childData=e.value}           </script>
    4.<script setup>需主动向父组件暴露子组件属性 :defineExpose

    使用 <script setup> 的组件,父组件是无法通过ref 或者 $parent 获取到子组件的ref等响应数据,需要通过defineExpose 主动暴露

    子组件代码:

    <script setup>import { ref } from 'vue'const a = 1const b = ref(2)//主动暴露组件属性defineExpose({  a,  b})</script>

    父组件代码:

    <template>  <div>父组件</div>  <Child  ref='childRef' />  <button @click='getChildData'>通过ref获取子组件的属性 </button></template><script setup>import {ref} from 'vue'import Child from './child.vue'const childRef= ref()  //注册响应数据  const getChildData =()=>{  //子组件接收暴露出来得值  console.log(childRef.value.a) //1  console.log(childRef.value.b) //2  响应式数据}    </script>
    5.语法糖其他功能

    useSlotsuseAttrs少用,由于大部分人是SFC模式开发,在<template/>通过<slot/>标签就可以渲染插槽)

    如果需要在script-setup中使用 slotsattrs 需要用useSlotsuseAttrs替代

    需要引入:import { useSlots ,useAttrs } fORM 'vue'

    <template/>中通过 $slots$attrs 来访问更方便(attrs用来获取父组件中非props的传递到子组件的参数/方法,attrs 用来获取父组件中非props的传递到子组件的参数/方法,attrs用来获取父组件中非props的传递到子组件的参数/方法,slots可以获取父组件中插槽传递的虚拟dom对象,在SFC模式应该用处不大,在jsX /TSX使用比较多)

    父组件:

    <template>  <Child msg="非porps传值子组件用attrs接收" >    <!-- 匿名插槽 -->    <span >默认插槽</span>    <!-- 具名插槽 -->    <template #title>      <h3>具名插槽</h3>    </template>    <!-- 作用域插槽 -->    <template #footer="{ scope }">      <footer>作用域插槽——姓名:{{ scope.name }},年龄{{ scope.age }}</footer>    </template>  </Child></template><script setup>// 引入子组件import Child from './child.vue'</script>

    子组件:

    <template>  <!-- 匿名插槽 -->  <slot />  <!-- 具名插槽 -->  <slot name="title" />  <!-- 作用域插槽 -->  <slot name="footer" :scope="state" />  <!-- $attrs 用来获取父组件中非props的传递到子组件的参数 -->  <p>{{ attrs.msg == $attrs.msg }}</p>  <!--true  没想到有啥作用... -->  <p>{{ slots == $slots }}</p></template>  <script setup>import { useSlots, useAttrs, Reactive, toRef } from 'vue'const state = reactive({  name: '张三',  age: '18'})const slots = useSlots()console.log(slots.default()); //获取到默认插槽的虚拟dom对象console.log(slots.title());   //获取到具名title插槽的虚拟dom对象// console.log(slots.footer()); //报错  不知道为啥有插槽作用域的无法获取//useAttrs() 用来获取父组件传递的过来的属性数据的(也就是非 props 的属性值)。const attrs = useAttrs()</script>

    useSlots或许在JSX/TSX下更实用

    想使用JSX语法在vite需要下载相关jsx的plugins才能识别jsx

    useSlots 可以获取父组件传递过来插槽的虚拟dom对象,可以用来渲染插槽内容

    <script lang='jsx'>import { defineComponent, useSlots } from "vue";export default defineComponent({  setup() {    // 获取插槽数据    const slots = useSlots();    // 渲染组件    return () => (      <div>        {slots.default?slots.default():''}        {slots.title?slots.title():''}      </div>    );  },});</script>

    大部分人是SFC模式开发,在<template/>通过<slot/>标签就可以渲染插槽,这种JSX 的写法应该是很少人会使用的

    6.在setup访问路由
    • 访问路由实例组件信息:route和router

    setup 里不能访问 this,不能再直接访问 this.$routerthis.$route。(getCurrentInstance可以替代this但不推荐)

    推荐:使用useRoute 函数和useRouter函数替代this.$routethis.$router

    <script setup>import { useRouter, useRoute } from 'vue-router'    const route = useRoute()    const router = useRouter()        function pushWithQuery(query) {      router.push({        name: 'search',        query: {          ...route.query,        },      })    }  <script/>
    • 导航守卫

    仍然可以使用路由实例组件的导航守卫

    import router from './router'router.beforeEach((to,from,next)=&gt;{})

    也可以使用组合式api的导航守卫onBeforeRouteLeave, onBeforeRouteUpdate

    <script setup>import { onBeforeRouteLeave, onBeforeRouteUpdate } from 'vue-router'    // 与 beforeRouteLeave 相同,无法访问 `this`    onBeforeRouteLeave((to, from) => {      const answer = window.confirm(        'Do you really want to leave? you have unsaved changes!'      )      // 取消导航并停留在同一页面上      if (!answer) return false    })    const userData = ref()    // 与 beforeRouteUpdate 相同,无法访问 `this`    onBeforeRouteUpdate(async (to, from) => {      //仅当 id 更改时才获取用户,例如仅 query 或 hash 值已更改      if (to.params.id !== from.params.id) {        userData.value = await fetchUser(to.params.id)      }    }) <script/>

    组合式 API 守卫也可以用在任何由 `<router-view>` 渲染的组件中,它们不必像组件内守卫那样直接用在路由组件上。

    以上就是关于“Vue3如何使用setup语法糖拒绝写return”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网精选频道。

    --结束END--

    本文标题: Vue3如何使用setup语法糖拒绝写return

    本文链接: https://www.lsjlt.com/news/357964.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • Vue3如何使用setup语法糖拒绝写return
      这篇“Vue3如何使用setup语法糖拒绝写return”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue3如何使用set...
      99+
      2023-07-06
    • Vue3怎么使用setup语法糖拒绝写return
      defineProps 代替props接收父组件传递的数据(父组件向子组件传参)父组件:<template> <div>父组件</div> <Child :title="msg&q...
      99+
      2023-05-14
      Vue3 return setup
    • Vue3编程流畅技巧使用setup语法糖拒绝写return
      目录Vue3.2 setup语法糖1.<script setup>在<template/>使用2、<script setup>引入组件将自动注册3...
      99+
      2024-04-02
    • vue3:setup语法糖使用教程
      目录1.setup语法糖简介2.setup语法糖中新增的api2.1defineProps2.2defineEmits2.3defineExpose补充:与普通的script一起使用...
      99+
      2024-04-02
    • 详解如何在Vue3使用<scriptlang=“ts“setup>语法糖
      目录迁移组件隐式返回definePropsdefineEmits默认关闭和defineExposeVue 3.2 引入了语法,这是一种稍微不那么冗长的声明组件的方式。您可以通过向 S...
      99+
      2024-04-02
    • 如何在Vue3中使用<script lang=“ts“ setup>语法糖
      这篇“如何在Vue3中使用<script lang=“ts“ setup>语法糖”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下...
      99+
      2023-07-06
    • 如何在vue3中同时使用tsx与setup语法糖
      目录前言Tsx与setup语法糖的优势遇到的问题最后前言 想这样做的原因是在vue3里使用tsx开发时,props的声明显得异常麻烦,不禁想到defineProps的便利,但同时在v...
      99+
      2024-04-02
    • Vue3中的script setup语法糖怎么使用
      这篇文章主要介绍了Vue3中的script setup语法糖怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue3中的script setup语法糖怎么使用文章都会有所收获,下面我们一起来看看吧。scr...
      99+
      2023-07-04
    • vue3更新的setup语法糖怎么用
      本文小编为大家详细介绍“vue3更新的setup语法糖怎么用”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue3更新的setup语法糖怎么用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。语法糖用法://&nb...
      99+
      2023-06-30
    • vue3 setup语法糖各种语法新特性的使用方法(vue3+vite+pinia)
      目录一、背景二、vue3语法的使用2.1. 父子通信props2.2. EventBus2.3. 计算属性computed2.4. pinia状态管理器的使用2.4.1. 模块化2....
      99+
      2024-04-02
    • 怎么在Vue3中使用<script lang=“ts“ setup>语法糖
      迁移组件以下组件有两个道具(要显示的和一个标志)。通过另一个组件,计算模板中显示的小马图像的URL,基于这两个道具。该组件还会在用户单击它时发出一个事件。The image selected while the Ponypony ...
      99+
      2023-05-16
      Vue3 setup
    • Vue3中的setup语法糖、computed函数、watch函数如何用
      computed函数computed 函数的使用:其实我们什么情况下会使用计算属性呢,那一定是通过依赖的数据得到新的数据!1)从Vue中引入computed 2)在setup中进行使用,将一个函数,函数的返回值就是计算好的数据 3)最后呢通...
      99+
      2023-05-17
      Vue3 setup computed
    • Vue3中的setup语法糖、computed函数、watch函数怎么使用
      这篇文章主要介绍“Vue3中的setup语法糖、computed函数、watch函数怎么使用”,在日常操作中,相信很多人在Vue3中的setup语法糖、computed函数、watch函数怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简...
      99+
      2023-07-05
    • 一文搞懂Vue3.2中setup语法糖使用
      目录前言一、如何使用setup语法糖二、data数据的使用三、method方法的使用四、watchEffect的使用五、watch的使用六、computed计算属性的使用七、prop...
      99+
      2024-04-02
    • Vue3.2 setup语法糖及Hook函数基本使用
      目录引言setup(语法糖)1、基本使用2、自动注册3、组件通信defineEmit ----> [子组件向父组件事件传递] 代码示列:defineExpose ---->...
      99+
      2024-04-02
    • vue3中setup语法糖下通用的分页插件实例详解
      目录vue3中setup语法糖下父子组件之间的通信准备工作父传子:子传父:先给大家介绍下vue3中setup语法糖下通用的分页插件,内容如下所示: 效果 自定义分页插件:PageP...
      99+
      2022-11-13
      vue3 setup语法糖 vue3 分页插件 vue父子组件
    • vue3基于script setup语法$refs的使用
      目录一、vue2语法二、vue3使用1. 组件设置ref值2. 组件实例获取3. 子组件内设置对外公开的变量一、vue2语法 vue2语法在组件上设置ref属性后,在代码里可以通过 ...
      99+
      2024-04-02
    • 如何进行vue3基于script setup语法$refs的使用
      如何进行vue3基于script setup语法$refs的使用,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、vue2语法vue2语法在组件上设置ref属性后...
      99+
      2023-06-22
    • 前端vue3的setup如何使用
      本文小编为大家详细介绍“前端vue3的setup如何使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“前端vue3的setup如何使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。vue3 中新增了 setup...
      99+
      2023-06-29
    • Vue3.2中如何使用语法糖
      今天小编给大家分享一下Vue3.2中如何使用语法糖的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一. 概述在Vue2时期,组...
      99+
      2023-07-04
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作