Vue3---(2)setup

概述

Vue 3 引入了 setup 语法,使 Composition API 成为核心特性之一。它相比 Options API 提供了更清晰的逻辑组织,提高了代码可维护性。组件中所用到的:数据、方法、计算属性、监视......等等,均配置在setup中。

基本语法

传统 setup

xml 复制代码
<script lang="ts">
  export default {
    name:'Test',
    setup(){
      // 数据(vue2 写在data中)
      let name = '张三'
      let age = 18
      // 方法(vue2 写在method中)
      function test(){
        name = 'zhang-san' //注意:此时这么修改name页面是不变化的
        console.log(name)
      }
      // 返回一个对象,对象中的内容,模板中可以直接使用
      return {name,age,test}
    }
  }
</script>

注意:setup返回值如果返回一个对象,那么对象的属性方法都可以在模板中使用,但是如果返回一个函数,则可以自定义渲染内容

javascript 复制代码
setup(){
 return ()=>'自定义文字显示'
}

<script setup>

不需要 return,变量和方法会自动暴露给 template

xml 复制代码
<script setup lang="ts">

  // 数据
  let name = '张三'
  let age = 18
  // 方法
  function test(){
  }
</script>

扩展:上述代码,还需要编写一个不写setupscript标签,去指定组件名字,比较麻烦,我们可以借助vite中的插件简化

  1. npm i vite-plugin-vue-setup-extend -D
  2. vite.config.ts中使用插件
  3. <script setup lang="ts" name="Person">
javascript 复制代码
import { defineConfig } from 'vite'
import VueSetupName from 'vite-plugin-vue-setup-extend'

export default defineConfig({
  plugins: [ VueSetupName () ]
})

执行时机

  • beforeCreate 之前执行
  • 不能访问 this (因为 this 还未初始化,this输出为undefined)
  • 只能在 <script setup>setup() 中使用

重点

  1. 可与vue2中的data,method,computed 等混用,而且在data,method...中也可以访问到setup中的属性和方法(因为setup先执行,数据方法都挂载到vm上,可以通过this访问到)
  2. setup不能访问vue2中的配置(data,method),原因在于setup先执行,此时this还是undefined

相关推荐
计算机程序设计小李同学10 分钟前
个人数据管理系统
java·vue.js·spring boot·后端·web安全
JosieBook1 小时前
【Vue】09 Vue技术——JavaScript 数据代理的实现与应用
前端·javascript·vue.js
Eason_Lou1 小时前
webstorm开发vue项目快捷跳转到vue文件
ide·vue.js·webstorm
起名时在学Aiifox1 小时前
前端文件下载功能深度解析:从基础实现到企业级方案
前端·vue.js·typescript
云上凯歌2 小时前
01 ruoyi-vue-pro框架架构剖析
前端·vue.js·架构
毕设十刻4 小时前
基于Vue的迅读网上书城22f4d(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
爱健身的小刘同学4 小时前
Vue 3 + Leaflet 地图可视化
前端·javascript·vue.js
musashi5 小时前
用 Electron 写了一个 macOS 版本的 wallpaper(附源码、下载地址)
前端·vue.js·electron
徐徐子5 小时前
从vue3 watch开始理解Vue的响应式原理
前端·vue.js
嘉琪0017 小时前
provide 和 inject的理解?
前端·javascript·vue.js