首页 > 其他分享 >setup语法糖

setup语法糖

时间:2022-12-28 13:33:44浏览次数:41  
标签:vue const setup 语法 组件 import defineProps

Vue3.2 版本开始才能使用语法糖!

什么是 setup script

它是 Vue3 的一个新语法糖,在 setup 函数中。所有 ES 模块导出都被认为是暴露给上下文的值,并包含在 setup() 返回对象中。相对于之前的写法,使用后,语法也变得更简单。
使用方式极其简单,仅需要在 script 标签加上 setup 关键字即可。示例:

<script setup></script>

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

组件自动注册

在 script setup 中,引入的组件可以直接使用,无需再通过 components 进行注册,并且无法指定当前组件的名字,它会自动以文件名为主,也就是不用再写 name 属性了。示例:

<template>
  <Child />
</template>

<script setup>
import Child from "./Child.vue";
</script>

属性和方法无需返回

<script setup>中无需 return 声明的变量、函数

<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>

使用 props

defineProps 代替 props,接收父组件传递的数据(父组件向子组件传参)

<script setup>
  // import { defineProps } from "vue";
  // defineProps在<script setup>中自动可用,无需导入
  // 需在.eslintrc.js文件中【globals】下配置【defineProps: true】
  const props = defineProps({
    title: String,
  });
</script>

使用 emits

defineEmit 代替 emit,子组件向父组件传递数据(子组件向外暴露数据)

<script setup>
// import { defineEmits } from "vue";
// defineEmits<script setup>中自动可用,无需导入
// 需在.eslintrc.js文件中【globals】下配置【defineEmits: true】
const emit = defineEmits(["change", "delete"]);
</script>

组件之间使用 v-model

  1. 子组件
<template>
  <span @click="changeInfo">我叫{{ modelValue }},今年{{ age }}岁</span>
</template>

<script setup>
defineProps({
  modelValue: String,
  age: Number,
});

const emit = defineEmits(["update:modelValue", "update:age"]);
const changeInfo = () => {
  // 触发父组件值更新
  emit("update:modelValue", "Tom");
  emit("update:age", 30);
};
</script>
  1. 父组件
<template>
  <!-- v-model:modelValue简写为v-model // 可绑定多个v-model -->
  <child v-model="state.name" v-model:age="state.age" />
</template>

<script setup>
import { reactive } from "vue";
// 引入子组件
import child from "./child.vue";
const state = reactive({
  name: "Jerry",
  age: 20,
});
</script>

获取 slots 和 attrs

可以通过useContext从上下文中获取 slots 和 attrs。不过提案在正式通过后,废除了这个语法,被拆分成了useAttrsuseSlots

<!--旧-->
<script setup>
import { useContext } from "vue";
const { slots, attrs } = useContext();
</script>

<!--新-->
<script setup>
import { useAttrs, useSlots } from "vue";
const attrs = useAttrs();
const slots = useSlots();
</script>

defineExpose API

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

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

在 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/>

路由导航守卫

<script setup>
import { onBeforeRouteLeave, onBeforeRouteUpdate } from "vue-router";

// 添加一个导航守卫,在当前组件将要离开时触发。
onBeforeRouteLeave((to, from, next) => {
  next();
});

// 添加一个导航守卫,在当前组件更新时触发。
// 在当前路由改变,但是该组件被复用时调用。
onBeforeRouteUpdate((to, from, next) => {
  next();
});
</script>

生命周期

通过在生命周期钩子前面加上 “on” 来访问组件的生命周期钩子。

下表包含如何在 Option API 和 setup() 内部调用生命周期钩子

Option API setup 中
beforeCreate 不需要
created 不需要
beforeMount onBeforeMount
mounted onMounted
beforeUpdate onBeforeUpdate
updated onUpdated
beforeUnmount onBeforeUnmount
unmounted onUnmounted
errorCaptured onErrorCaptured
renderTracked onRenderTracked
renderTriggered onRenderTriggered
activated onActivated
deactivated onDeactivated

原型绑定与组件内使用

  1. main.js
import { createApp } from "vue";
import App from "./App.vue";
const app = createApp(App);

// 获取原型
const prototype = app.config.globalProperties;

// 绑定参数
prototype.name = "Jerry";
  1. 组件内使用
<script setup>
import { getCurrentInstance } from "vue";

// 获取原型
const { proxy } = getCurrentInstance();

// 输出
console.log(proxy.name);
</script>

v-bind() CSS 变量注入

<template>
  <span>Jerry</span>
</template>

<script setup>
import { ref, reactive } from "vue";
// prop接收样式
const props = defineProps({
  border: {
    type: String,
    default: "1px solid yellow",
  },
});

// 常量声明样式
const background = "red";

// 响应式数据声明样式
const color = ref("blue");
const style = reactive({
  opacity: "0.8",
});
</script>

<style lang="scss" scoped>
span {
  // 使用常量声明的样式
  background: v-bind(background);

  // 使用响应式数据声明的样式
  color: v-bind(color);
  opacity: v-bind("style.opacity");

  // 使用prop接收的样式
  border: v-bind("props.border");
}
</style>

标签:vue,const,setup,语法,组件,import,defineProps
From: https://www.cnblogs.com/icey-Tang/p/17009944.html

相关文章

  • Python 缩进语法的起源:上世纪 60-70 年代的大胆创意!
    上个月,Python之父GuidovanRossum在推特上转发了一篇文章《​​TheOriginsofPython​​》,引起了我的强烈兴趣。众所周知,Guido在1989年圣诞节期间开始创造Python,......
  • 第一篇 MarkDown语法
    一级标题前面加一个井号后空格二级两个井号三级三个井号字体效果(*~不加空格)helloword两边加两个**加粗,helloword两边各加一个星号变斜体helloword两边......
  • YAML 文件基本语法格式(十四)
    一、YAML文件基本语法格式前面我们得Kubernetes集群已经搭建成功了,现在我们就可以在集群里面来跑我们的应用了。要在集群里面运行我们自己的应用,首先我们需要知道几个......
  • Vue3之setup的两个注意点
    setup的两个注意点setup执行的时机在beforeCreate之前执行一次,this是undefined。setup的参数props:值为对象,包含:组件外部传递过来,且组件内部声明接收了的属性。......
  • Vue3之setup
    setupsetup是vue3中的一个新的配置项,值为一个函数,我们在组件中用到的数据、方法等等,都要配置在setup中。setup函数的返回值有两种1、返回一个渲染函数,可以自定义渲染内容......
  • Shell笔记:编写脚本常用语法
    本文记录的是工作中编写脚本的常用语法整理,比较零散,有错欢迎指正。一、文件第一行文件的第一行通常为#!/bin/bash或#!/bin/sh,#!用于指定这个脚本文件使用什么解释......
  • MarkDown语法
    Markdown学习标题三级标题四级标题 #+空格一级标题##+空格二级标题###+空格三级标题 字体Hello,world!  两边加**表示粗体Hello,world!   两边加......
  • 新概念英语一册语法总结
    目录​​1、简单句的句型结构:​​​​   1-1、简单句​​​​   1-2、句子组织的5步骤:​​​​2、否定句:​​​​3、倒装句(就近原则):​​​​4、一般疑问句:​​​​5......
  • 4、搜索引擎语法
    Google搜索site:baidu.com可以查看子域名inurl:.php?id=搜索我们指定的字符是否存在于URL中intext:管理将返回所有在网页正文部分包含关键词的网页intitle:管理将返......
  • JSP的基本语法
    文章目录​​一.JSP(JavaServerPage)概述​​​​1.定义​​​​2.JSP是一个动态网页​​​​3.注意事项​​​​二.JSP页面元素​​​​1.注释​​​​(1).HTML注......