treegrid 如何获取getchanges inserted_如何避开Vue性能优化之路的荆棘?

随着这几年前端技术快速发展,Vue框架在国内普及率极高,人人都会用,那Vue如何写得比别人优雅?如何写得比别人漂亮?

鉴于一线互联网大厂在前沿技术领域的持续研究和大规模投入,直接向他们取经,是最便捷也是最高效的学习方式。但对于中小公司工作的程序员来说,平时忙碌于业务代码,却很少有机会接触到大厂的优秀实践。

本文将介绍一些大厂Vue项目的最佳实践:

305ed0f68745da2699b5552443197a4a.png

1

一劳永逸的组件注册

通常在组件使用前,需要引入后再注册,但如果高频组件多了后,每次都这样做,不仅新增很多代码,效率还低!我们应该如何优化呢?

其实,我们可以借助一下webpack的require.context() 方法来创建自己的(模块)上下文,从而实现自动动态require组件。

我们先在components文件夹(这里面都是些高频组件)添加一个叫global.js的文件,在这个文件里使用require.context 动态将需要的高频组件统统打包进来,然后在main.js文件中引入global.js的文件。

//  global.js文件import Vue from 'vue'function changeStr (str) {  return str.charAt(0).toUpperCase() + str.slice(1)}const requireComponent = require.context('./', false, /\.vue$/)// 查找同级目录下以vue结尾的组件const install = () => {  requireComponent.keys().forEach(fileName => {    let config = requireComponent(fileName)    console.log(config) // ./child1.vue 然后用正则拿到child1    let componentName = changeStr(      fileName.replace(/^\.\//, '').replace(/\.\w+$/, '')    )    Vue.component(componentName, config.default || config)  })}export default {  install // 对外暴露install方法}

最后我们就可以随时随地在页面中使用这些高频组件,无需再手动一个个引入了。

2

高精度权限控制--自定义指令directive

我们通常给一个元素添加 v-if / v-show 来做权限管理,但如果判断条件繁琐且多个地方需要判断,这种方式的代码不仅不优雅而且冗余。

针对这种情况,我们可以通过全局自定义指令来处理:我们先在新建个 array.js 文件,用于存放与权限相关的全局函数;

// array.jsexport function checkArray (key) {  let arr = ['1', '2', '3', '4', 'demo']  let index = arr.indexOf(key)  if (index > -1) {    return true // 有权限  } else {    return false // 无权限  }}
然后在将 array 文件挂载到全局中:
// main.jsimport { checkArray } from "./common/array";Vue.directive("permission", {  inserted (el, binding) {    let permission = binding.value; // 获取到 v-permission的值    if (permission) {      let hasPermission = checkArray(permission);      if (!hasPermission) { // 没有权限 移除Dom元素        el.parentNode && el.parentNode.removeChild(el);      }    }  }});
最后我们在页面中就可以通过自定义指令 v-permission 来判断:
 
class="btns"> <button v-permission="'1'">权限按钮1button> // 会显示    "'10'">权限按钮2</button>  // 无显示    权限按钮3button> // 会显示 </div>以上是我分享几个Vue大厂实战经验。大家有没有想过一个问题?随着前端面试要求越来越高,像Vue这样的框架已经是基本功,我们凭什么敢说比别人厉害呢?我们都会写组件,但是你知道怎么让组件能够成为高复用性的组件库型组件吗?我们都会项目打包上线,但是你知道如何编写配置文件能让打包速度最优化吗?我们都会写路由,但是你知道如何写才能保证多路由模块解耦,保证更方便增加新的路由模块吗?前端全方面学习需要完整的前端思路实践教学,这边准备了一份前端路径完整图供大家学习:

d9fb2deb8266f73754e3fef214c04325.png

扫码领取前端工程师学习成长思维导图

04b57efb54baa2a7d214259f61c8a7ec.png

当然,有这些还不够,因为目前是否积累优秀实战经验已经成为区分前端水平高低的评判标准,这边推荐网易云课堂的进阶课程,大家可以去这儿学习下大厂的优秀实践。想进阶自己的Vue技能,学习更多的大厂实践技能的前端小伙伴可以去这里学习一下前端课程。

5.6-5.9前端直播课程

一、技术:《带你深度解析日常写的webpack配置》1、代码分割到底是在分割什么2、开发模式怎么手动搭建3、大厂面试题分析二、项目:《如何从api层入手,让你的项目做的更好更快》1、如何管理自己的项目api层 2、axios拦截思路3、如何二次封装请求库扫码领取0元前端进阶系列直播课

04b57efb54baa2a7d214259f61c8a7ec.png

更有前端进阶资料包免费赠送

9e2c5199739bed2fffff85276673fb18.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/559350.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

matlab+信号+mpf,Python和Matlab中平均频率的差异

我有这个EMG signal&#xff0c;我想根据这个article绘制平均功率频率。我使用以下代码在Matlab中实现它&#xff1a;clear all;close all;EMGload(EMG.txt);N1000; %my windowz1;fs200 %sampling ratefor i1:length(EMG)-NDUM0;NUM0;FTfft(EMG(i:iN-1));psdFT.*conj(FT);NFFTl…

matlab和vlfeat关联,VLFeat在matlab和vs中安装

转&#xff1a;http://blog.csdn.net/u011718701/article/details/51452011博主最近用vlfeat库做课题&#xff0c;网上搜索使用方法&#xff0c;一大片都会告诉你说&#xff1a;run(/vl_setup) 然后就好啦哈哈哈哈哈哈~~~~~~~~~~~~~~But!理想很丰满&#xff0c;现实很骨感&…

document.createelement如何绑定点击事件_番外篇-EXCEL如何使用宏(VBA)

小编&#xff0c;会在后续推送一些关于VBA(宏)相关的文章(之前其实也推送了一些&#xff0c;其中也大概说了一下如何使用)&#xff0c;所以我们今天就专门写一篇如何使用宏&#xff0c;方便大家使用已经写好的宏。如何使用宏&#xff1a;常规宏VBA-一般都是此类1、调出-开发工具…

局域网打印机反应慢_为什么你的Excel这么慢,这些原因必须要知道!

Excel是很多人的高频办公工具&#xff0c;但大家或多或少地遇到过&#xff0c;有时自己电脑的Excel很慢&#xff0c;导致工作的效率不高&#xff0c;可能就会导致要加班加点&#xff0c;也压缩了自己其他方面的时间。本文将介绍一些常见的Excel”慢“的情况及其解决方案&#x…

linux挂载fc存储有超级坏块_Nand Flash基础知识与坏块管理机制的研究

欢迎FPGA工程师加入官方微信技术群点击蓝字关注我们FPGA之家-中国最好最大的FPGA纯工程师社群概述Flash名称的由来&#xff0c;Flash的擦除操作是以block块为单位的&#xff0c;与此相对应的是其他很多存储设备&#xff0c;是以bit位为最小读取/写入的单位&#xff0c;Flash是一…

carsim中质心加速度_振动CAE分析在空调压缩机支架设计中的应用

【摘要】本文运用有限元分析方法分析空调压缩机系统模态&#xff0c;并通过分析引起振动的激励源&#xff0c;找出压缩机支架和安装螺栓断裂的根本原因&#xff0c;并根据分析提出了解决措施。关键词&#xff1a;空调压缩机支架模态激励共振一、引言发动机轮系需要驱动的工作部…

linux下usb驱动配置文件,Linux环境下USB的原理、驱动和配置

随着生活水平的提高&#xff0c;人们对USB设备的使用也越来越多&#xff0c;鉴于Linux在硬件配置上尚不能全部即插即用&#xff0c;因此关于Linux如何配置和使用&#xff0c;成为困扰我们的一大问题。本文引用地址&#xff1a;http://www.eepw.com.cn/article/70029.htmlinux操…

linux 内核重定位,Linux 内核学习笔记:预备知识之“目标文件”

8种机械键盘轴体对比本人程序员&#xff0c;要买一个写代码的键盘&#xff0c;请问红轴和茶轴怎么选&#xff1f;本文主要阐述 Linux 的目标文件(有可重定位目标文件、可执行目标文件和共享目标文件三种形式)&#xff0c;并把重点放在其格式和案例分析上。注&#xff1a;一般情…

linux虚拟内存api,Linux虚拟内存空间分布-Go语言中文社区

平常总说cpu的位数&#xff0c;其实说的是cpu一次能运算的最长整数的宽度&#xff0c;既ALU(算术逻辑单元)的宽度。cpu的位数也是数据总线的条数数据总线&#xff1a;数据线的总和&#xff0c;数据线就是cpu与内存进行数据传递的通道&#xff0c;一条数据线&#xff0c;一次可以…

2019 d serv 激活_化疗过程中肌肉减少症的发生机制及维生素D、ω-3脂肪酸的作用...

文章来源&#xff1a;蔡丽雅,赵文芝,杨振鹏,贺源,邓丽,张艳,石汉平.肿瘤化疗过程中肌肉减少症的发生机制及维生素D、ω-3脂肪酸的作用[J].中国医学前沿杂志(电子版),2020,12(1):13-19.正 文1998年&#xff0c;Baumgartner等【1】首次提出“肌肉减少症”的概念&#xff0c;用以描…

电脑鸿蒙运行Linux程序,Linux下的Hi3861一站式鸿蒙开发烧录(附工具)-鸿蒙开发烧录工具软件电脑版-东坡下载...

HarmonyOS 智能设备一站式集成开发环境&#xff0c;支持 HarmonyOS 组件按需定制、一键编译和烧录、可视化调试、分布式能力集成等&#xff0c;帮助开发者高效开发和创新新硬件。介绍2021春节前夕&#xff0c;华为发布了 HUAWEI DevEco Device Tool 2.0 Beta1&#xff0c;整体提…

终端软件_DMSTerminal现场管控终端软件正式发布

目前军工企业的信息化建设及管理大多停留在企业内部的管理层&#xff0c;各种任务信息、作业流程等无法直接下达到真正的一线现场层&#xff0c;导致工作在一线的大量技术人员仍然使用传统的纸质工单、纸质记录、口头交流等工作模式进行现场工作。很多工作模式普遍都是以人力来…

深度残差网络_注意力机制+软阈值化=深度残差收缩网络

顾名思义&#xff0c;深度残差收缩网络是由“残差网络”和“收缩”两部分所组成的&#xff0c;是在“残差网络”基础上的一种改进算法。其中&#xff0c;残差网络在2016年斩获了ImageNet图像识别竞赛的冠军&#xff0c;目前已经成为了深度学习领域的基础网络&#xff1b;收缩就…

linux 网络io命令详解,Linux下五种网络IO模型详解

本文我们主要来了解一下Unix/Linux下5种网络IO模型&#xff1a;blocking IO, nonblocking IO, IO multiplexing, signal driven IO, asynchronous IO的基本原理&#xff0c;更好的理解在高级语言中的异步编程&#xff0c;一起来看看吧&#xff0c;希望对大家学习linux有所帮助。…

安卓与Linux共存,Android和Linux重新合并成一个操作系统

Linux又回到了Android中&#xff0c;Android又回到了Linux中。Android一直都是Linux&#xff0c;但多年来Android项目走了自己的路&#xff0c;它的代码没有被合并回主Linux树中。现在&#xff0c;比Linux的创始人和主要开发人员Linux的预期要快得多&#xff0c;Android已经正式…

edit控件自动换行 mfc_VS2010/MFC编程入门:如何创建对话框模板和修改对话框属性?...

创建对话框主要分两大步&#xff0c;第一&#xff0c;创建对话框资源&#xff0c;主要包括创建新的对话框模板、设置对话框属性和为对话框添加各种控件&#xff1b;第二&#xff0c;生成对话框类&#xff0c;主要包括新建对话框类、添加控件变量和控件的消息处理函数等。在本节…

linux vim tag,Vim基础知识之ctags 及 Taglist 插件

Vim基础知识之ctags 及 Taglist 插件1. 我的界面2. ctagsexuberant ctags是一般Linux系统上缺省的ctags我的ctags版本&#xff1a;Exuberant Ctags 5.9~svn20110310简单介绍Used in at least 50 countries in all 7 continents (including Antarctica!)Supports 41 programming…

c语言程序设计整人,C语言进程间通信练习作品 - 整人小程序之剪切板

主程序界面&#xff1a;程序介绍&#xff1a;如果对方执行了主程序生成的【server.exe】&#xff0c;【server.exe】会自复制、自启动、自删除(仿木马)。【server.exe】会后台每秒/次检测对方的剪切板&#xff0c;一有文本数据则在尾部加入【附加内容】&#xff0c;达到&#x…

Android怎么自定义充电铃声,安卓手机怎么自定义充电提示音_自定义安卓充电提示音教程_3DM手游...

安卓手机其实也是可以设置充电提示音的&#xff0c;我们只需要下载一个第三方软件&#xff0c;然后在APP中进行一些简单的设置&#xff0c;就可以实现自定义更换手机充电提示音了。安卓手机怎么自定义充电提示音&#xff1f;下面小编就为大家带来了详细的教程&#xff0c;希望能…

android logcat 根据包名过滤,adb logcat通过包名过滤(dos命令find后跟变量)

过滤条件&#xff1a;该app在运行实现原理&#xff1a;1、获取该app运行时的pid2、通过find命令&#xff0c;过滤pid的日志&#xff0c;就是该包的运行日志实现&#xff1a;1、在同一目录建立一文件&#xff1a;getpid.batecho offadb shell "ps | grep com.example.testp…