1、脚本设置

如果以前使用过组合 API,我们需要始终执行 defineComponent 和 setup() {}:

<script lang="ts">
import {defineComponent} from 'vue';
export default defineComponent({
 name: 'Test',
 setup() {
   //Add business logic
 }
})
</script>

对每个组件执行此操作可能会相当麻烦,实际上,可以避免对组件进行引导。可以使用 <script setup> ,它是如上所示执行相同操作的简写。它基本上只是顶部的语法糖,因此,不必每次都进行手动引导:使用 <script setup>,您的组件将被简化为:

<script lang="ts" setup>
 //Add business logic
</script>

2、如何覆盖反应对象

默认情况下,当定义一个响应式对象时,您不能覆盖整个对象,如果这样做,您将失去响应性。

<script lang="ts">
import { defineComponent, reactive, onMounted } from "vue";
export default defineComponent({
 name: "HelloWorld",
 setup() {
   let myReactiveObject = reactive({
     name: "Nicky",
     age: "37",
     country: "DK",
   });
   let newObject = {
     name: "Nicky Christensen",
     age: "36",
     country: "DA-DK",
   };
   onMounted(() => {
     setTimeout(() => {
       //myReactiveObject = newObject //Wont work
       Object.assign(myReactiveObject, newObject) //Will work
     }, 2000)
   })
   return {
     myReactiveObject,
   };
 },
});
</script>

查看此 Codesandbox 以了解其实际效果

3、反应式 CSS

在新版本的 Vue 中,一件非常棒的事情是,可以将 CSS 直接绑定到我们的变量中。我发现这对于我在去年构建的一些应用程序非常有用。

4、全局组件

时不时地,我们希望拥有全局可用的组件,而不是每次需要它们时都必须导入它们。

我们可以通过转到 main.ts 并执行以下操作轻松完成此操作:

import App from "./App.vue";
import MyGlobalSection from '@/components/MyGlobalSection.vue';
const app = createApp(App);
// Make our <MyGlobalSection /> component globally available.
app.component(MyGlobalSection.name, MyGlobalSection);
app.mount("#app");

现在,我们应该能够通过在要使用全局组件的组件中的模板中编写 <MyGlobalSection /> 来全局使用该组件

5、组合 API 优于选项 API

使用 Vue 3,我们获得了 Composition API。这是对 Vue 的一个真正伟大的补充,我认为总是选择使用 Composition API 而不是 Options API。

我喜欢 Composition API 的一点是,我发现它使用起来更灵活,而且我开始使用 composeables,它被认为是 mixins 的替代品。非常强大且非常酷的补充。

6、使用 v-once 或 v-memo 提高性能

如果你关心快速渲染,可能希望使用 Vue 的内置指令之一,例如 v-once 或 v-memo 来提高应用程序的渲染性能。

v-once,可以在多个元素中应用 v-once,例如常规元素、循环中或组件。

<template>
 <!-- single -->
 <p v-once>{{ someProperty }}</p>
 <!-- with children -->
 <div v-once>
   <p>{{ someProperty}}</p>
 </div>
 <!-- components -->
 <my-component v-once />
 <!-- v-for directives -->
 <li v-for="”item" in items” v-once>{{item}}</li>
</template>

v-memo;简而言之,v-memo 用于记忆模板的子树,这意味着它存储先前渲染的结果以加快未来渲染的速度。

v-memo 指令可用于元素和组件,并且可以。v-memo 接受一个数组,并且只有当数组中的一个值发生变化时才会重新渲染。

<div v-memo="[valueA, valueB]">
 ...
</div>

如果 valueA 或 valueB 发生变化,它将更新。但请注意,v-memo 在 v-for 循环中不起作用。

7、组件的异步加载

为了让你的应用程序更高效并最小化你的主包,延迟加载你的组件是个好主意。在 Vue3 中,我们可以使用 defineAsyncComponent 来延迟加载组件。

这意味着该组件仅在需要时才加载。使用这种技术,您可以显着改善应用程序的负载。

定义异步组件的最简单方法可以像这样完成:

import { defineAsyncComponent } from "vue";
// Lazy Load
const myComponent = defineAsyncComponent(() =>
 import("./components/myComponent.vue")
);

但是,如果您需要它,您可以做更多的事情,将对象传递给 defineAsyncComponent:

const myComponent = defineAsyncComponent({
 loader: () => import("./myComponent.vue"),
 loadingComponent: myLoadingComponent /* shows while loading */,
 errorComponent: myErrorComponent /* shows if there's an error */,
 delay: 1000 /* delay in ms before showing loading component */,
 timeout: 3000 /* timeout after this many ms */,
});

到此这篇关于分享7个成为更好的Vue开发者的技巧的文章就介绍到这了,更多相关Vue技巧内容请搜索Devmax以前的文章或继续浏览下面的相关文章希望大家以后多多支持Devmax!

分享7个成为更好的Vue开发者的技巧的更多相关文章

  1. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  2. 10 个Python中Pip的使用技巧分享

    众所周知,pip 可以安装、更新、卸载 Python 的第三方库,非常方便。本文小编为大家总结了Python中Pip的使用技巧,需要的可以参考一下

  3. vue自定义加载指令v-loading占位图指令v-showimg

    这篇文章主要为大家介绍了vue自定义加载指令和v-loading占位图指令v-showimg的示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  4. vue使用动画实现滚动表格效果

    这篇文章主要为大家详细介绍了vue使用动画实现滚动表格效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. 关于Vue 监控数组的问题

    这篇文章主要介绍了Vue 监控数组的示例,主要包括Vue 是如何追踪数据发生变化,Vue 如何更新数组以及为什么有些数组的数据变更不能被 Vue 监测到,对vue监控数组知识是面试比较常见的问题,感兴趣的朋友一起看看吧

  6. Vue子组件props从父组件接收数据并存入data

    这篇文章主要介绍了Vue子组件props从父组件接收数据并存入data的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  7. Vue h函数的使用详解

    本文主要介绍了Vue h函数的使用详解,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  8. VUE响应式原理的实现详解

    这篇文章主要为大家详细介绍了VUE响应式原理的实现,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助

  9. vue+Element ui实现照片墙效果

    这篇文章主要为大家详细介绍了vue+Element ui实现照片墙效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. vue+elemet实现表格手动合并行列

    这篇文章主要为大家详细介绍了vue+elemet实现表格手动合并行列,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

随机推荐

  1. js中‘!.’是什么意思

  2. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  3. 基于JavaScript编写一个图片转PDF转换器

    本文为大家介绍了一个简单的 JavaScript 项目,可以将图片转换为 PDF 文件。你可以从本地选择任何一张图片,只需点击一下即可将其转换为 PDF 文件,感兴趣的可以动手尝试一下

  4. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. AngularJs上传前预览图片的实例代码

    使用AngularJs进行开发,在项目中,经常会遇到上传图片后,需在一旁预览图片内容,怎么实现这样的功能呢?今天小编给大家分享AugularJs上传前预览图片的实现代码,需要的朋友参考下吧

  6. JavaScript面向对象编程入门教程

    这篇文章主要介绍了JavaScript面向对象编程的相关概念,例如类、对象、属性、方法等面向对象的术语,并以实例讲解各种术语的使用,非常好的一篇面向对象入门教程,其它语言也可以参考哦

  7. jQuery中的通配符选择器使用总结

    通配符在控制input标签时相当好用,这里简单进行了jQuery中的通配符选择器使用总结,需要的朋友可以参考下

  8. javascript 动态调整图片尺寸实现代码

    在自己的网站上更新文章时一个比较常见的问题是:文章插图太宽,使整个网页都变形了。如果对每个插图都先进行缩放再插入的话,太麻烦了。

  9. jquery ajaxfileupload异步上传插件

    这篇文章主要为大家详细介绍了jquery ajaxfileupload异步上传插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. React学习之受控组件与数据共享实例分析

    这篇文章主要介绍了React学习之受控组件与数据共享,结合实例形式分析了React受控组件与组件间数据共享相关原理与使用技巧,需要的朋友可以参考下

返回
顶部