2024年Web前端最新在vue中使用装饰器(1),2024最新大厂前端面经

基础面试题

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

主要内容包括:HTML,CSS,JavaScript,浏览器,性能优化等等

}

}

// 使用方式

class MyClass {

@debounce(100)

follow() {

console.log(‘关注我’)

}

}

我们逐行去分析一下代码

1、首先我们定义了一个 debounce函数,同时有一个参数wait,这个函数对应的就是在下面调用装饰器时使用的@debounce(100)

2、debounce函数返回了一个新的函数,这个函数即装饰器的核心,这个函数有三个参数,下面逐一分析 target:

这个类属性函数是在谁上面挂载的,如上例对应的是MyClass类 name: 这个类属性函数的名称,对应上面的follow

descriptor: 这个就是我们前面说的属性描述符,通过直接descriptor上面的属性,即可实现属性只读,数据重写等功能

3、然后第三行 descriptor.value = debounce(descriptor.value, wait),

前面我们已经了解到,属性描述符上面的value对应的是这个属性的值,所以我们通过重写这个属性,将其用debounce函数包装起来,这样在函数调用follow时实际调用的是包装后的函数

通过上面的三步,我们就实现了类属性上面可使用的装饰器,同时将其应用到了类属性上面

4、使用

=======================================================================

在Vue中使用装饰器

1、配置基础环境


除了一些老的项目,我们现在一般新建Vue项目的时候,都会选择使用脚手架vue-cli3/4来新建,这时候新建的项目已经默认支持了装饰器,不需要再配置太多额外的东西,如果你的项目使用了eslint,那么需要给eslint配置以下内容。

parserOptions: {

ecmaFeatures:{

// 支持装饰器

legacyDecorators: true

}

}

如果你使用的是vscode 可能还会遇到vetur的报错,在setting.js加上

“vetur.validation.script”: false,

2、使用装饰器


虽然Vue的组件,我们一般书写的时候export出去的是一个对象,但是这个并不影响我们直接在组件中使用装饰器,比如就拿上例中的log举例。

function log() {

/**

  • @param target 对应 methods 这个对象

  • @param name 对应属性方法的名称

  • @param descriptor 对应属性方法的修饰符

*/

return function(target, name, descriptor) {

console.log(target, name, descriptor)

const fn = descriptor.value

descriptor.value = function(…rest) {

console.log(这是调用方法【${name}】前打印的日志)

fn.call(this, …rest)

console.log(这是调用方法【${name}】后打印的日志)

}

}

}

export default {

created() {

this.getData()

},

methods: {

@log()

getData() {

console.log(‘获取数据’)

}

}

}

看了上面的代码,是不是发现在Vue中使用装饰器还是很简单的,和在class的属性上面使用的方式一模一样,但有一点需要注意,在methods里面的方法上面使用装饰器,这时候装饰器的target对应的是methods。

除了在methods上面可以使用装饰器之外,你也可以在生命周期钩子函数上面使用装饰器,这时候target对应的是整个组件对象。

3、一些常用的装饰器


1. 函数节流与防抖

函数节流与防抖应用场景是比较广的,一般使用时候会通过throttle或debounce方法对要调用的函数进行包装,现在就可以使用上文说的内容将这两个函数封装成装饰器, 防抖节流使用的是lodash提供的方法,大家也可以自行实现节流防抖函数

import { throttle, debounce } from ‘lodash’

/**

  • 函数节流装饰器

  • @param {number} wait 节流的毫秒

  • @param {Object} options 节流选项对象

  • [options.leading=true] (boolean): 指定调用在节流开始前。

  • [options.trailing=true] (boolean): 指定调用在节流结束后。

*/

export const throttle = function(wait, options = {}) {

return function(target, name, descriptor) {

descriptor.value = throttle(descriptor.value, wait, options)

}

}

/**

  • 函数防抖装饰器

  • @param {number} wait 需要延迟的毫秒数。

  • @param {Object} options 选项对象

  • [options.leading=false] (boolean): 指定在延迟开始前调用。

  • [options.maxWait] (number): 设置 func 允许被延迟的最大值。

  • [options.trailing=true] (boolean): 指定在延迟结束后调用。

*/

export const debounce = function(wait, options = {}) {

return function(target, name, descriptor) {

descriptor.value = debounce(descriptor.value, wait, options)

}

}

封装完之后,在组件中使用

import {debounce} from ‘@/decorator’

export default {

methods:{

@debounce(100)

resize(){}

}

}

2、确认框

当你点击删除按钮的时候,一般都需要弹出一个提示框让用户确认是否删除,这时候常规写法可能是这样的

import { Dialog } from ‘vant’

export default {

methods: {

deleteData() {

Dialog.confirm({

title: ‘提示’,

message: ‘确定要删除数据,此操作不可回退。’

}).then(() => {

console.log(‘在这里做删除操作’)

})

}

}

}

我们可以把上面确认的过程提出来做成装饰器,如下代码

最后

面试题千万不要死记,一定要自己理解,用自己的方式表达出来,在这里预祝各位成功拿下自己心仪的offer。
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

大厂面试题

面试题目录

最后

面试题千万不要死记,一定要自己理解,用自己的方式表达出来,在这里预祝各位成功拿下自己心仪的offer。
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

[外链图片转存中…(img-MCxlboGf-1715459310829)]

[外链图片转存中…(img-YcDaad0x-1715459310830)]

[外链图片转存中…(img-7ZrWVgMf-1715459310830)]

[外链图片转存中…(img-nuAqZiPU-1715459310831)]

  • 22
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值