【免费送书】7个让我们成为更好 Vue 开发者的技巧

35548c933733771ca53ea6ca64211f8d.png

来源 | https://medium.com/js-dojo/vue-3-tips-tricks-d820b04f452f

我使用 Vue 已经很多年了,特别是去年一直在使用 Vue3,因此,学到了很多东西,在这篇文章中,我将与你分享7个关于Vue3的技巧,希望对你有帮助。

01、脚本设置

如果以前使用过组合 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>

02、如何覆盖反应对象

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

<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 以了解其实际效果:https://codesandbox.io/s/lingering-http-ryf2bj?file=/src/components/HelloWorld.vue

03、反应式 CSS

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

........
const color = ref('#f000');<style>
.text {
  color: v-bind(color); 
}
</style>

04、全局组件

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

我们可以通过转到 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 /> 来全局使用该组件

05、组合 API 优于选项 API

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

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

06、使用 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 循环中不起作用。

07、组件的异步加载

为了让你的应用程序更高效并最小化你的主包,延迟加载你的组件是个好主意。 在 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 */,
});

感谢您的阅读,希望您喜欢这篇文章,如果喜欢,请点赞我,关注我,以表示对我的支持。

到这里,我们今天跟你分享的内容就结束了。

但是,我今天还给大家带来了一个新福利,免费送书活动,请继续往下看。

免费赠书活动规则

1、必须是关注了我们【web前端开发】公众号的读者。

2、要在留言区里给我们留言,说说你为啥想要这本书,或者是你的编程趣事。

3、留言点赞数最高的前6位读者朋友们(点赞数相同按系统顺序排序),就可以免费把这本《Vue.JS从入门到项目实战》书领回家。

这3点必须同时满足哦~

活动截止时间:2022年6月21日晚上9点,中奖者名单,将在2021年6月22日的头条文章推送中的PS里进行公布,请大家自行关注。

所赠送图书均包邮到家。

赠送图书的图片如下:

99bcf67346789171db90cc2be70e7a33.png

同时,你也可以通过以下地址进行购买此图书。

图书内容介绍

d44229aac117258ef3947c365d981a1f.png

图书产品图片来源京东网

最后,说一句,中奖的小伙们,别忘记添加我的微信号:【web_xiaoer】,备注:图书中奖以便于通过,谢谢合作。

学习更多技能

请点击下方公众号

1c79fe562de68a4c38e54a8b6399001a.gif

975593e95cad93229b5a7734f64d76f8.png

9863a0fc5e04749f7f61e1139a0d3489.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值