vue的高级实战技巧

今天从四个方面给大家分享一下vue的实战技巧
1.全局组件注册
2.render函数拯救繁乱的template
3.vue权限控制
4.路由的优化
下面我们开始吧!

全局组件注册

先看看我们平时注册组件是如何做的


微信图片_20191018153204.png

当我们需要在HelloWorld里面引入child1和child2的时候,我们一般先通过import导入这两个文件,然后通过components注册,这样就能使用了,这只是在一个文件里面引入,如果还有别的文件也需要引入,我们又得这样重复一遍,或者说如果HelloWorld还需要引入几十个组件,按照这个写法会显得非常的繁琐而且低效,那怎么写才能更高效呢?且看下面:


微信图片_20191018153929.png

首先我们在与组件同级的地方新建一个golbal.js,这个js的作用就是帮助我们全局组件注册,其中require.context它是一个webpack的api,通过执行require.context函数获取一个特定的上下文,主要用来实现自动化导入模块,它接收三个参数:
1.directory {String} -读取文件的路径
2.useSubdirectories {Boolean} -是否遍历文件的子目录
3.regExp {RegExp} -匹配文件的正则

requireComponent.keys()获取到的是一个数组,
微信图片_20191021111704.png

接着匹配 / 和.vue中间的字符串并且用过changeStr()方法将首字符转换为大写,这个得到的就是我们需要的组件名称。最后通过Vue.component()方法注册
注意:哪些组件可以全局注册?如果只是用到一次两次的可以不需要注册为全局的,如果是频繁使用的,比如弹窗,提示语在很多页面都会用到,这种情况下就可以使用全局注册了。

最后还有一点,需要在main.js里面进入global.js

render函数拯救繁乱的template

因为template存在一值多判的情况,这样就会导致代码冗余,代码杂乱的结果,这种时候就可以使用render函数来优化,我们先看下一值多判的情况:

<template>
  <div v-if="value === 1">
    <button>按钮1</button>
  </div>
<div v-if="value === 2">
    <button>按钮1</button>
  </div>
<div v-if="value === 3">
    <button>按钮1</button>
  </div>
</template>

那么我们如何使用render来优化呢?
首先父组件

<template>
  <div id="app">
    <Button 
      :type="type"
      :text="text"
      @myEvent="myDemo">
    </Button>
  </div>
</template>

<script>
import Button from './button'
export default {
  name: 'App',
  data(){
    return{
      type:'danger',
      text:1
    }
  },
  compontents:{Button},
  methods:{
    myDemo(){
      console.log(111)
    }
  }
}
</script>

render组件:

<script>
export default {
  name: 'Button',
  props:{
    type:{
      type:String,
      defalut:'normal'
    },
    text:{
      type:String,
      defalut:'normal'
    }
  },
  render(h){
    return h('button',{
      //v-bind:class
      class:{
        'btn':true,
        'btn-success': this.type === 'success',
        'btn-danger': this.type === 'danger',
        'btn-warning': this.type === 'warning',
        'normal' : !this.type
      },
      //dom
      domprops:{
        innerText: this.text || '默认'
      },
      on:{
        click: handleClck
      }
    })
  },
  methods:{
    handleClck(){
      this.$emit('myEvent')
    }
  }
}
</script>

<style>
.btn {
  width: 100px;
  height: 40px;
  line-height: 40px;
  color: #ffffff;
}
.btn-success {
  background: green;
}
.btn-danger {
  background: red;
}
.btn-warning {
  background: orange;
}
.btn-normal {
  background: gray;
}
</style>

vue权限控制

当我们需要根据某些特殊的权限对应显示页面的操作的时候,一般情况下我们是这样写

<template>
  <div id="app">
    <div v-show="isShow">
      <div>我是权限1</div>
    </div>
    <div>
      <div>我是权限2</div>
    </div>
    <div>
      <div>我是权限3</div>
    </div>
  </div>
</template>

<script>
export default {
  name: 'App',
  data(){
    return {
      isShow:false
    }
  }
}
</script>

这种写法存在安全问题,现在我们可以写一个全局的权限控制指令
首先我们新建一个array.js

export function checkArray(key){
    //权限数组
    let arr = ['1','2','3',5];
    let index = arr.indexOf(key);
    if(index > -1){
        return
    } else {
        return false
    }
}

然后在main.js里面引入这个方法,并写一个指令

import {checkArray} from './assets/common/array.js'
Vue.config.productionTip = false
Vue.directive('display-key',{
  inserted(el,binding){
    let displayKey = binding.value;
    if(displayKey){
      let hasPermission = checkArray(displayKey);
      //如果没有权限则删除dom
      if(!hasPermission){
        el.parentNode && el.parentNode.removeChild(el);
      }
    } else {
      throw new Error('需要传key')
    }
  }
})

最后在dom里面使用自定义指令

<div v-display-key="'1'">
  <div>我是权限1</div>
 </div>

路由引入优化

通常情况下我们的router.js是这样的

import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'
Vue.use(Router)
export default new Router({
  routes: [
    {
      path: '/',
      name: 'HelloWorld',
      component: HelloWorld
    }
  ]
})

这只是一个路由,如果有几十个甚至上百个呢,再使用这样的写法会显得太凌乱,并且很不好维护,接下来我们可以优化下
router.js

import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'
Vue.use(Router)

//重点
const routerList = [];
function importAll(r){
  r.keys().forEach(
    (key) => routerList.push(r(key).default)
  );
}
importAll(require.context('.',true,/\.router\.js/));
export default new Router({
  routes: [
    ...routerList,
    {
      path: '/',
      name: 'HelloWorld',
      component: HelloWorld
    }
  ]
})

项目目录结构


WechatIMG456.jpeg

以上就是vue的一些实战技巧,也可以说是优化技巧。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,454评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,553评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,921评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,648评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,770评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,950评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,090评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,817评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,275评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,592评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,724评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,409评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,052评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,815评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,043评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,503评论 2 361
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,627评论 2 350