返回顶部
首页 > 资讯 > 前端开发 > JavaScript >15个Vue技巧,你都知道吗
  • 474
分享到

15个Vue技巧,你都知道吗

2024-04-02 19:04:59 474人浏览 安东尼
摘要

目录前言1、将一个prop限制在一个类型的列表中2、使用引号来监听嵌套属性3、知道何时使用v-if4、单个作用域插槽的简写5、将局部和全局的style混合在一起6、重写子组件的样式7

前言

学习成为一个更好的 Vue 开发者,并不总是关于那些需要花时间和精力才能掌握的大概念。

掌握一些技巧和窍门,可以让我们的编程生活变得更容易--没有大量重复的工作。

在使用 Vue 开发的这几年里,掌握一些有用的技巧,使用一些更高级的技术点,总会有用的。

1、将一个 prop 限制在一个类型的列表中

我们在使用 prop 时,可能会有时候需要判断该 prop 是否在我们规定的范围内(或者说规定的值内),此时可以使用 prop 定义中的 validator 选项,将一个 prop 类型限制在一组特定的值中。

export default {
  name: 'Test',
  props: {
    name: {
      type: String,
    },
    size: {
      type: String,
      validator: s => ['small', 'middle'].includes(s)
    }
  }
};

这个验证函数接受一个 prop,如果 prop 有效或无效,则返回 true 或 false。当单单传入的 true 或 false 来控制某些条件不能满足需求时,我通常使用这个方法来做。

2、使用引号来监听嵌套属性

你可能使用过 watch 来监听过某个属性,但是你可能不知道这一点,我们可以通过使用引号轻松地直接监听嵌套值

watch {
  'obj.message.name'() {
    // ...
  }
}

3、知道何时使用 v-if

有时候使用 v-if,往往使用 v-show 来代替,会有更高的性能。

<TableList v-show="isshow" />

当 v-if 被打开或关闭时,它将创建并完全销毁该元素。相反,v-show 将创建该元素并将其留在那里,通过设置其样式为 display: none 来隐藏它,如果你要切换的组件的渲染成本很高,那么这样做会更有效率,特别是对于结构复杂的组件或页面来说,更推荐使用 v-show。

反过来说,如果不需要立即执行昂贵的组件,可以使用 v-if,这样它就会跳过渲染它,而使页面的加载速度更快一些。

4、单个作用域插槽的简写

限定范围的插槽非常有趣,但为了使用它们,您还必须使用许多模板标记。幸运的是,有一个简写可以让我们摆脱它,但只有在我们使用单个作用域槽的情况下。

你或许这样使用过

<TableList>
  <template #header="attrList">
    <TableHeader v-bind="attrList" />
  </template>
</TableList>

不使用 template

<TableList #header="attrList">
  <TableHeader v-bind="attrList" />
</TableList>

简单、直截了当,令人赞叹不已。

5、将局部和全局的 style 混合在一起

通常情况下,在处理样式时,我们希望它们只在当前组件内起作用

<style scoped>
  .content {
    background: green;
  }
</style>

不过,如果需要的话,也可以添加一个非作用域样式块来添加全局样式

<style>
  
  .content p {
    font-size: 12px;
  }
</style>
 
<style scoped>
  
  .content {
    background: green;
  }
</style>

需要注意,全局样式是危险的,难以追踪。但有时,它们是一个完美的逃生舱口,正是你所需要的。

6、重写子组件的样式

Scoped CSS 在保持内容整洁方面非常棒,而且不会将样式引入应用的其他组件中。但有时我们需要覆盖一个子组件的样式,并跳出这个作用域。

Vue 有一个 deep 选择器可以完成以上功能

<style scoped>
.my-content >>> .child-component {
  font-size: 16px;
}
</style>

注意:如果你使用像 LESS 这样的 CSS 预处理器,你可能需要使用 /deep/ 来代替

<style lang="less" scoped>
.my-content /deep/ .child-component {
  font-size: 16px;
}
</style>

7、如何在 Vue 之外创建一个具有响应性的变量

如果你从 Vue 之外得到一个变量,让它具有反应性是很好的。这样,我们就可以在 computed props、watch 和其他任何地方使用它,它的工作方式就像 Vue 中的任何其他状态一样。

如果我们使用的选项 api,需要的只是将其放在组件的数据部分中

const externalVariable = getValue();
 
export default {
  data() {
    return {
      ReactiveVariable: externalVariable,
    };
  }
};

如果使用 vue3 的组合 API,可以直接使用 ref 或 reactive

import { ref } from 'vue';
 
// 可以完全在 Vue 组件之外完成
const externalVariable = getValue();
const reactiveVariable = ref(externalVariable);   //使用ref使其具有响应性

使用 reactive 代替

import { reactive } from 'vue';
 
//  可以完全在 Vue 组件之外完成
const externalVariable = getValue();
// reactive 只对对象和数组起作用
const anotherReactiveVariable = reactive(externalVariable);

如果你还在使用 Vue2,你可以使用 observable 而不是 reactive 来实现完全相同的结果

import Vue from 'vue'
 
//  可以完全在 Vue 组件之外完成
const externalVariable = getValue();
const anotherReactiveVariable = Vue.observable(externalVariable);

8、v-for 中的解构

你是否在v-for 中使用解构?

// users: [{name:'leo',id:'1'},{name:'lion',id:'2'}]
<li
  v-for="{ name, id } in users"
  :key="id"
>
  {{ name }}
</li>

更广为人知的是,可以通过使用这样的元组从 v-for 中取出索引

<li v-for="(movie, index) in [
  'Lion King',
  'Frozen',
  'The Princess Bride'
]">
  {{ index + 1 }} => {{ movie }}
</li>

当使用一个对象时,可以这样使用 key

<li v-for="(value, key) in {
  name: 'Lion King',
  released: 2019,
  director: 'Jon Favreau',
}">
  {{ key }}: {{ value }}
</li>

也可以将这两种方法结合起来,获取 key 以及属性的 index

<li v-for="(value, key, index) in {
  name: 'Lion King',
  released: 2019,
  director: 'Jon Favreau',
}">
  {{ index + 1 }} => {{ key }}: {{ value }}
</li>

9、在指定范围内循环

v-for 允许我们遍历数组,也允许我们遍历一个范围

<template>
  <ul>
    <li v-for="num in 6">Item {{ num }}</li>
  </ul>
</template>

渲染结果

Item 1
Item 2
Item 3
Item 4
Item 5
Item 6

这里有个注意点,当我们使用 v-for 遍历一个范围时,它将从 1 开始,以我们指定的数字结束。

10、窃取 prop 类型

我们从一个子组件中复制 prop 类型,只是为了在一个父组件中使用它们。但是往往偷取这些 prop 类型要比仅仅复制它们好得多,什么意思?

举个例子,我们在某个组件中使用了一个 List 组件

<template>
  <div>
    <h2>{{ title }}</h2>
    <List
      :type="listType"
      :size="listSize"
      :name="listName"
    />
  </div>
</template>

为了让它正常工作,我们需要添加正确的 prop 类型,从 List 组件复制

import List from './List';
export default {
  components: { List },
  props: {
    listType: {
      type: String,
      required: true,
    },
    listSize: {
      type: String,
      default: 'medium',
      validator: size => [
        'small',
        'medium',
        'large',
        'x-large'
      ].includes(size),
    },
    listName: {
      type: String,
      default: 'list',
    },
    title: {
      type: String,
      required: true,
    },
  },
};

看下来,有没有觉得很麻烦?

当 List 组件的 prop 类型被更新时,我们肯定会忘记返回这个组件并更新它们。随着时间的推移,当该组件的 prop 类型开始偏离 List 组件中的 prop 类型时,就会引入错误。

因此,这就是为什么我们要窃取组件的 prop 类型,具体如下

import List from './List';
export default {
  components: { List },
  props: {
    ...List.props,  // 窃取List的prop,不需要再重复累赘地一一列出
    title: {
      type: String,
      required: true,
    },
  },
};

这样是不是简便了很多?

除了在上面的例子中,我们把 List 加在每个 prop 名称的开头。所以我们必须做一些额外的工作来实现这一点

import List from './List';
 
const listProps = {};
 
Object.entries(List.props).forEach((key, val) => {
  listProps[`list${key.toUpperCase()}`] = val;
});
 
export default {
  components: { List },
  props: {
    ...listProps,
    title: {
      type: String,
      required: true,
    },
  },
};

现在,如果 List 组件中的 prop 类型被修改,我们的组件将保持最新状态。但是,如果一个 prop 类型从 List 组件中被添加或删除了呢?为了应对这些情况,我们可以使用 v-bind 和一个计算的 prop 来保持动态。

11、检测元素外部(或内部)的单击

当我们需要检测一个点击是发生在一个特定元素 el 的内部还是外部,通常使用的方法

window.addEventListener('click', e => {
  // 获取被点击的元素
  const currtentEl = e.target;
 
  // 检测在el元素的内部还是外部
  if (el.contains(currtentEl)) {
   // 在el里面点击了
  } else {
   // 在el外面点击了
  }
});

12、从组件外部调用一个方法

我们可以从一个组件的外部通过给它一个 ref 用来调用一个方法

<!-- Parent.vue -->
<template>
  <Child ref="child" />
</template>
 
// 在该组件调用子组件的方法
this.$refs.child.method();

通常情况下,我们使用 props 和 events 在组件之间进行交流。props 被下发到子组件中,而 events 被上发到父组件中

<template>
  <Child
    :tell-me-what-to-do="someInstructions"
    @something-happened="hereIWillHelpYouWithThat"
  />
</template>
 
// Child.vue
export default {
  props: ['trigger'],
  watch: {
    shouldCallMethod(newVal) {
      if (newVal) {
        // Call the method when the trigger is set to `true`
        this.method();
      }
    }
  }
}

这可以正常工作,但只能在第一次调用时使用。如果您需要多次触发此操作,则必须进行清理并重置状态。逻辑如下

  • 父组件将 true 传递给触发器 prop
  • Watch 被触发,然后 Child 组件调用该方法
  • 子组件发出一个事件,告诉父组件该方法已被成功触发
  • Parent 组件将 trigger 重置为 false,所以我们可以从头再来一次 

相反,如果我们在子组件上设置一个 ref,我们可以直接调用该方法(如最开始的方式),我们打破了 “props down, events up” 的规则,我们打破了封装,但是这样做更清晰,更容易理解。

13、监听数组和对象

有时候使用 watcher 不能正确触发,很多情况下是因为我们试图监听数组或对象,但没有将 deep 设置为 true

export default {
  name: 'namesChange',
  props: {
    names: {
      type: Array,
      required: true,
    },
  },
  watch: {
    names: {
      // 这将让 Vue 知道要在数组内部寻找,如不添加,则不能进行深度监听
      deep: true,
 
      handler(newVal,oldVal)
        console.log('The list of names has changed!');
      }
    }
  }
}

在vue3中使用

watch(
  names,
  (newVal,oldVal) => {
    console.log('The list of names has changed!');
  },
  {
    deep: true,
  }
);

14、template 标签的另一个用途

template 标签可以在模板中的任何地方使用,以更好地组织代码。有时它来简化 v-if 逻辑,有时也用 v-for。如下,我们有几个元素都使用同一个 v-if 条件

<template>
  <div class="card">
    <img src="imgPath" />
    <h3>
      {{ title }}
    </h3>
    <h4 v-if="expanded">
      {{ subheading }}
    </h4>
    <div
      v-if="expanded"
      class="card-content"
    >
      <slot />
    </div>
    <SocialShare v-if="expanded" />
  </div>
</template>

仔细观察上面的代码,我们会发现一些元素的显示与隐藏的条件是一样的,但是这样写并不友好,当在一个更大、更复杂的组件上,有可能是一个糟糕的情况。

我们可以使用 template 标签来分组这些元素(v-if 条件一致的元素),并将 v-if 提升到模板 template 本身,达到优化的目的

<template>
  <div class="card">
    <img src="imgPath" />
    <h3>
      {{ title }}
    </h3>
    <!-- 将 v-if 提升到分组上 -->
    <template v-if="expanded">
      <h4>
        {{ subheading }}
      </h4>
      <div class="card-content">
        <slot />
      </div>
      <SocialShare />
    </template>
  </div>
</template>

现在看起来清晰了许多,也更容易理解,而且它在做什么,一目了然。

15、处理错误(和警告)的更好方法

我们可以为 Vue 中的错误和警告提供一个全局的自定义处理程序

// Vue 2
Vue.config.errorHandler = (err) => {
  alert(err);
};
 
// Vue 3
const app = createApp(App);
app.config.errorHandler = (err) => {
  alert(err);
};

当然你也可以用它们来更优雅地处理错误,以获得更好的用户体验。例如,如果一个错误未被处理,应用程序不会直接崩溃,而是显示一个完整的错误屏幕,提示用户刷新或尝试其他操作。

到此这篇关于15个Vue技巧,你都知道吗的文章就介绍到这了,更多相关Vue 技巧内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 15个Vue技巧,你都知道吗

本文链接: https://lsjlt.com/news/140711.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 15个Vue技巧,你都知道吗
    目录前言1、将一个prop限制在一个类型的列表中2、使用引号来监听嵌套属性3、知道何时使用v-if4、单个作用域插槽的简写5、将局部和全局的style混合在一起6、重写子组件的样式7...
    99+
    2024-04-02
  • 在Python中f-string的几个技巧,你都知道吗
    目录最基础用法自记录表达式多行f-string在f-string中格式化日期控制浮点数精度标准化显示宽度修改为左对齐设置科学计数法格式控制有效数字位数f-string想必很多Pyth...
    99+
    2024-04-02
  • JavaScript的这5个技巧你知道了吗
    JavaScript的这5个技巧你知道了吗,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。谁要是说 JavaScript 是世界上比较好的语言,...
    99+
    2024-04-02
  • 简单的这些不为人知的小技巧你都知道吗?
      随着科技的发展,手机在生活越来越重要,微信渐渐成为我们生活中沟通的重要媒介。现在很多的中老年人也开始使用微信了,但是微信上有很多功能,他们都不会使用,如果我们不在他们的身边,他们又想使用微信的话,那...
    99+
    2024-04-02
  • Spring异步编程的5个技巧:你知道吗?
    在现代的Web应用程序中,异步编程已经成为了不可或缺的一部分。Spring框架是一个非常流行的Java开发框架,它提供了多种异步编程的方式来帮助开发人员构建高效的Web应用程序。在本文中,我们将介绍Spring异步编程的5个技巧,让你更好...
    99+
    2023-10-08
    django spring 异步编程
  • 一定要知道的 25 个 Vue 技巧
    目录1. 将 prop 限制为类型列表2. 默认内容和扩展点3. 使用引号观察嵌套值4. 知道何时使用 v-if(以及何时避免使用)5. 单作用域 slot 的简写(不需要模板标签!...
    99+
    2024-04-02
  • JavaScript循环遍历的24个方法,你都知道吗
    目录前言一、数组遍历方法1. forEach()2. map()3. for of4. filter()5. some()、every()6. reduce()、reduceRigh...
    99+
    2024-04-02
  • PHP 和 NPM 的函数打包技巧,你知道吗?
    在前端和后端开发中,函数打包技巧是非常重要的一环。无论是在 PHP 还是 NPM 中,都有一些技巧可以帮助我们更加高效地编写和管理函数。在本文中,我们将介绍一些常用的技巧,并且会结合实例进行演示。 一、PHP 函数打包技巧 使用命名空间...
    99+
    2023-09-12
    npm 函数 打包
  • NumPy数组索引的秘密技巧,你知道吗?
    当我们在使用NumPy处理数据时,经常会遇到需要对数组进行索引和切片的情况。虽然NumPy提供了很多基础的索引和切片操作,但是在实际应用中,我们还需要掌握一些高级的技巧来更好地处理数据。在本文中,我们将介绍一些NumPy数组索引的秘密技巧,...
    99+
    2023-08-04
    numy 索引 打包
  • Unix 下的 Python 数组打包技巧,你知道吗?
    Python 是一种简单易用的编程语言,被广泛应用于数据分析、科学计算、Web 开发等领域。在 Python 中,数组是一种非常常见的数据结构,用于存储一组有序的数据。而数组打包则是一种常见的操作,它可以将多个数组合并成一个数组。 在 U...
    99+
    2023-11-02
    数组 unix 打包
  • React的三大属性你都知道吗
    目录React三大属性props函数组件类组件state有状态组件和无状态组件setStateprops和state属性的区别refsReact.createRefref的绑定总结R...
    99+
    2024-04-02
  • 学习ASP框架的10个技巧,你知道几个?
    ASP框架(Active Server Pages)是微软公司推出的一种服务器端脚本语言,用于动态创建交互式网页和Web应用程序。ASP框架是一种非常流行的Web开发框架,因为它可以轻松地与其他Microsoft技术(如SQL Serve...
    99+
    2023-08-05
    框架 教程 学习笔记
  • 微信的这些不为人知的小技巧,你都知道哪些呢?
      随着科技的发展,手机在生活越来越重要,微信渐渐成为我们生活中沟通的重要媒介。现在很多的中老年人也开始使用微信了,但是微信上有很多功能,他们都不会使用,如果我们不在他们的身边,他们又想使用微信的话,那...
    99+
    2024-04-02
  • ASP和JavaScript实时教程:你知道这些技巧吗?
    在Web开发中,ASP和JavaScript是两个非常重要的技术。它们可以让你创建动态的网站,实现实时交互和数据处理。在本文中,我们将介绍一些ASP和JavaScript的实时教程和技巧,帮助你更好地使用它们。 ASP是一种服务端脚本语言...
    99+
    2023-09-27
    javascript 实时 教程
  • Java编程中的算法优化技巧,你知道吗?
    Java是一种高级编程语言,被广泛应用于各种领域。在Java编程中,算法是非常重要的一部分。优化算法可以提高程序的执行效率,降低资源消耗,提高用户体验。本文将介绍一些Java编程中的算法优化技巧,帮助读者更好地编写高效的Java程序。 1...
    99+
    2023-09-12
    编程算法 unix path
  • 你知道吗?ASP IDE 接口存储的使用技巧!
    ASP IDE 接口存储的使用技巧 ASP(Active Server Pages)是一种基于服务器端脚本的动态网页技术,它可以生成动态的网页内容。在开发ASP网站时,我们通常会使用集成开发环境(IDE)来编写和调试代码。ASP IDE接口...
    99+
    2023-10-15
    ide 接口 存储
  • 编程中Load算法的应用技巧,你知道吗?
    Load算法是计算机科学中非常常见的一种算法,它被广泛应用于各种领域,如数据库、操作系统、网络等。本文将为大家介绍Load算法的概念以及在编程中的应用技巧,并附上相应的演示代码。 一、Load算法的概念 Load算法是一种基于平均负载的负...
    99+
    2023-08-15
    面试 load 编程算法
  • Javascript数组常用方法你都知道吗
    我用这些方法主要从五个方面去学习。 1.方法是干什么的。 2.谁能用 (当然是数组啦)。 3.有没有返回值,返回值是什么。 4.修不修改原来的对象。 5.如何使用。 接下来就是干货了...
    99+
    2024-04-02
  • Java函数编程的5个必备算法,你都知道吗?
    Java是一种非常流行的编程语言,具有强大的函数编程能力。在函数编程中,算法是至关重要的。本文将介绍Java函数编程的5个必备算法。 阶乘算法 阶乘是一个非常基本的数学概念,表示一个自然数的所有小于等于它的正整数的乘积。阶乘算法的实现可...
    99+
    2023-08-31
    函数 编程算法 git
  • Vue的基本知识你都了解吗
    目录1. Vue的基本知识1.1 Vue的使用1.2 插值语法1.3 v-bind(单向绑定)1.4 v-model(双向绑定)1.4.1 v-model和v-bind的区别1.4....
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作