当前位置:首页 > 科技  > 软件

用这五个技巧将你的Vue技能提升到新的高度

来源: 责编: 时间:2023-08-09 23:02:54 485观看
导读在这篇文章中,我们将探讨五个实用的 Vue 技巧,这些技巧可以使你日常使用 Vue 编程更高效、更富有成效。无论你是Vue的初学者还是经验丰富的开发者,这些技巧都能帮助你编写更清晰、更简洁、更有效的代码。那么,让我们开始

在这篇文章中,我们将探讨五个实用的 Vue 技巧,这些技巧可以使你日常使用 Vue 编程更高效、更富有成效。无论你是Vue的初学者还是经验丰富的开发者,这些技巧都能帮助你编写更清晰、更简洁、更有效的代码。那么,让我们开始吧。r7Z28资讯网——每日最新资讯28at.com

1. 在不失去反应性的情况下解构属性

在 Vue 中,Props  是父子组件之间传递数据的强大方式。Prop 数据是响应性的,这意味着在父组件中对道具值的更改将反映在接收 Prop 的子组件中。然而,子组件不能直接修改 Prop 的值。相反,它应该发出一个事件来通知父组件更新 Prop。r7Z28资讯网——每日最新资讯28at.com

在解构 Vue 的props时,prop数据在过程中会失去反应性。然而,有一种方法可以在解构props时保持反应性。你可以使用toRefs指令来包装props对象,并在解构过程中保持反应性。有了这个指令,你可以在不担心失去反应性的情况下解构prop数据。r7Z28资讯网——每日最新资讯28at.com

<script setup lang="ts">import { toRefs } from 'vue'const props = withDefaults(  defineProps<{    event: object;    address: string;  }>(),  {});const { address } = toRefs(props)</script><template>  <class="font-medium bg-gray-100 text-gray-700 py-3 px-3 rounded">      {{ address }}  </div></template>

2. 创建自定义指令

Vue 指令是可以添加到HTML元素的特殊属性,它们让你能够将动态数据和行为绑定到元素上。在Vue.js中,指令通过属性名上的 v- 前缀来识别,并用于为HTML元素提供额外的功能。r7Z28资讯网——每日最新资讯28at.com

一些最常用的 vue 指令包括:v-if,v-html,v-on,v-bind,v-pre,v-once 等等。在vuejs中,你可以创建自定义指令来执行特定的任务。我们将创建一个自定义的v-model指令,用于将输入标签中输入的文本转化为大写。r7Z28资讯网——每日最新资讯28at.com

<script setup>  import { ref, vModelText } from 'vue'  const value = ref("")  // 为' v-model '指令定义一个名为'capitalize '的自定义修饰符  vModelText.beforeUpdate = function (el, { value, modifiers }) {    // 检查' v-model '指令中是否存在' capitalize '修饰符    if (value && modifiers.capitalize) {      el.value = el.value.toUpperCase()    }  }</script><template>  <input type="text" v-model.capitalize="value" /></template>

指令是 Vue 中的一个强大功能,它允许你为应用程序的用户界面添加动态功能。通过利用指令,我们可以创建更具交互性和响应性的应用程序,这些应用程序更易于维护和更新。r7Z28资讯网——每日最新资讯28at.com

3. 针对Vue的性能标记

在应用程序中追踪性能瓶颈非常重要,尤其是当你想要构建高性能的应用程序时。Vue 有一个特定的功能,可以在Chrome DevTools中启用性能标记。r7Z28资讯网——每日最新资讯28at.com

要在开发模式中启用性能标记,可以将 performance  选项设置为 true。这样我们能够在浏览器开发工具的性能/时间线面板中追踪组件的初始化、编译、渲染和性能追踪。r7Z28资讯网——每日最新资讯28at.com

import { createApp } from "vue";import App from "./App.vue";import router from "./router";import { createPinia } from "pinia";import piniaPluginPersistedstate from "pinia-plugin-persistedstate";import { createHead } from "unhead";import "./style.css";const pinia = createPinia();createHead();pinia.use(piniaPluginPersistedstate);const app = createApp(App);if (process.env.NODE_ENV === "development") {  app.config.performance = true;}app.use(router);app.use(pinia);app.mount("#app");

唯一的注意事项是,它只能在开发模式下以及支持性能标记API的浏览器中运行r7Z28资讯网——每日最新资讯28at.com

4. 从组件外部调用方法

在Vue 中,我们可以借助 defineExpose 宏从特定组件外部调用方法。这在处理某种方式上相互依赖的多个组件时特别有用。r7Z28资讯网——每日最新资讯28at.com

defineExpose 宏可以暴露出组件属性,这些属性可以在其他组件中通过refs进行访问,从而允许你在特定组件中调用方法。这也可以让你访问变量声明,props 等等。r7Z28资讯网——每日最新资讯28at.com

<script setup lang="ts">  function doSomething(){    // do smething  }  defineExpose({ doSomething });</script><div>  <h1>Child component</h1> </div>

现在我们可以在任何地方导入该组件,并按照下面的示例调用其中的各种方法。r7Z28资讯网——每日最新资讯28at.com

<script setup lang="ts">import { ref, onMounted} from 'vue';import ChildComponent from './ChildComponent';const childComponent = ref();onMounted(() => {  childComponent.value.doSomething();});</script><id="app">  <ChildComponent ref="childComponent" /></div>

5. 持久化Pinia 存储

Pinia,是 Vue3 推荐的 store ,Pinia 简化了 store实现,并且轻量级且具有性能优势。使用 Pinia 管理 store时,持久化 store 数据非常重要。r7Z28资讯网——每日最新资讯28at.com

pinia-plugin-persistedstate 是一个高度可定制的包,为这项任务提供自定义存储、序列化器和路径选择选项。r7Z28资讯网——每日最新资讯28at.com

请使用您喜欢的包管理器按照下面的方式安装 pinia-plugin-persistedstate:r7Z28资讯网——每日最新资讯28at.com

pnpm : pnpm i pinia-plugin-persistedstatenpm : npm i pinia-plugin-persistedstateyarn : yarn add pinia-plugin-persistedstate

需要在 main.js 或 main.ts 文件中进行配置,如下所示。r7Z28资讯网——每日最新资讯28at.com

import { createApp } from "vue";import App from "./App.vue";import router from "./router";import { createPinia } from "pinia";import piniaPluginPersistedstate from "pinia-plugin-persistedstate";import { createHead } from "unhead";import "./style.css";const pinia = createPinia();createHead();// inject piniaPluginPersistedstate to piniapinia.use(piniaPluginPersistedstate);const app = createApp(App);app.use(router);app.use(pinia);app.mount("#app");

通过在您的 store  中将 persist 属性设置为 true,启用Pinia存储持久性:r7Z28资讯网——每日最新资讯28at.com

import { defineStore } from "pinia";export const uselistingStore = defineStore(`listingStore`, {  state: () => {    return {      data: [],    };  },  persist: true,  actions: {  },  getters: {  },});

总结

总的来说,这五个Vue.js的技巧可以极大地提升你的开发流程,使你的代码更高效、更有效。从不失去反应性地解构属性,到在Pinia中持久化存储状态,再到在组件外部访问组件方法,这些技巧可以帮助你提升你的Vue. 技能。r7Z28资讯网——每日最新资讯28at.com

r7Z28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-5151-0.html用这五个技巧将你的Vue技能提升到新的高度

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 你喜欢哪种文档标记语言?

下一篇: 如何使用Asp.net Core实现定时任务,轻松解决任务调度问题!

标签:
  • 热门焦点
  • 5月安卓手机好评榜:魅族20 Pro夺冠

    性能榜和性价比榜之后,我们来看最后的安卓手机好评榜,数据来源安兔兔评测,收集时间2023年5月1日至5月31日,仅限国内市场。第一名:魅族20 Pro好评率:97.50%不得不感慨魅族老品牌还
  • CSS单标签实现转转logo

    转转品牌升级后更新了全新的Logo,今天我们用纯CSS来实现转转的新Logo,为了有一定的挑战性,这里我们只使用一个标签实现,将最大化的使用CSS能力完成Logo的绘制与动画效果。新logo
  • K8S | Service服务发现

    一、背景在微服务架构中,这里以开发环境「Dev」为基础来描述,在K8S集群中通常会开放:路由网关、注册中心、配置中心等相关服务,可以被集群外部访问;图片对于测试「Tes」环境或者
  • 10天营收超1亿美元,《星铁》比《原神》差在哪?

    来源:伯虎财经作者:陈平安即便你没玩过《原神》,你一定听说过的它的大名。恨它的人把《原神》开服那天称作是中国游戏史上最黑暗的一天,有粉丝因为索尼在PS平台上线《原神》,怒而
  • 认真聊聊东方甄选:如何告别低垂的果实

    来源:山核桃作者:财经无忌爆火一年后,俞敏洪和他的东方甄选依旧是颇受外界关心的&ldquo;网红&rdquo;。7月5日至9日,为期5天的东方甄选&ldquo;甘肃行&rdquo;首次在自有App内直播,
  • 携众多高端产品亮相ChinaJoy,小米带来一场科技与人文的视听盛宴

    7月28日,全球数字娱乐领域最具知名度与影响力的年度盛会中国国际数码互动娱乐展览会(简称ChinaJoy)在上海新国际博览中心盛大开幕。作为全球领先的科
  • 华为HarmonyOS 4升级计划公布:首批34款机型今日开启公测

    8月4日消息,今天下午华为正式发布了HarmonyOS 4系统,在更流畅的前提下,还带来了不少新功能,UI设计也有变化,会让手机焕然一新。华为宣布,首批机型将会在
  • iQOO Neo8 Pro真机谍照曝光:天玑9200+和V1+旗舰双芯加持

    去年10月,iQOO推出了iQOO Neo7系列机型,不仅搭载了天玑9000+,而且是同价位唯一一款天玑9000+直屏旗舰,一经上市便受到了用户的广泛关注。在时隔半年后,
  • 世界人工智能大会国际日开幕式活动在世博展览馆开启

    30日上午,世界人工智能大会国际日开幕式活动在世博展览馆开启,聚集国际城市代表、重量级院士专家、国际创新企业代表,共同打造人工智能交流平台。上海市副市
Top