Vue之mixin全局的用法详解


Posted in Javascript onAugust 22, 2018

先贴上官方定义。

个人觉得全局mixin就是给全部Vue文件添加一些公用的实例(方法,过滤器and so on)

使用场景:货币单位,时间格式。这些如果在用到的页面使用的话代码会重复的很多,所以在全局混入这些实例会减少代码量,可维护性也比较高。

ex:

step1: 先定义mixin.js

const mixin = {
 methods: {
  /**
   * 格式化时间
   * @param {string|number|object|Array} dateTime - 时间,可以是一个字符串、时间戳、表示时间的对象、Date对象或者******表示时间的数组
   * @param {string} [fmt] - 格式
   * @returns {string} 返回格式化后的日期时间,默认格式:2018年1月11日 15:00
   * @see [momentjs]{@tutorial http://momentjs.cn/}
   */
  formatDate (dateTime, fmt = 'YYYY年M月DD日 HH:mm:ss') {
   if (!dateTime) {
    return ''
   }
   moment.locale('zh-CN')
   dateTime = moment(dateTime).format(fmt)
   return dateTime
  }
 }
}export defaullt mixin

step2:在main.js文件里面

import mixin from './mixin'
Vue.mixin(mixin)

全局混入是.mixin没有s

step3:在你的vue文件里面就可以使用mixin里面定义好的东西比如

 

data() {
  return {
   userName: "等你",
   time: this.formatDate(new Date()),
   arr: [1,2,3,4,5,'文字'],
   result: []
  }
 }

这个vue文件的数据源data里面的time就是引用混入进来的方法。

使用mixins里的方法

设置路由

// src/router/index.js
import Vue from 'vue'
import Router from 'vue-router'
Vue.use(Router)

export default new Router({
 mode:'history',
 routes: [
  {
   path:'/',
   redirect:'/index'
  },
  {
   path: '/about',
   name: 'About',
   component:resolve => require(['@/pages/About'],resolve)
  },
  {
   path: '/index',
   name: 'Index',
   component:resolve => require(['@/pages/Index'],resolve)
  },
  {
   path: '/product',
   name: 'Product',
   component:resolve => require(['@/pages/Product'],resolve)
  }
 ]
})

页面调用mixins里的loadPage方法

<p @click="loadPage('Index')">Index</p>

Index页面如下

// src/pages/Index
<template>
 <div>
  <p>这是index页面</p>
  <p @click="loadPage('Index')">Index</p>
  <p @click="loadPage('About')">About</p>
  <p @click="loadPage('Product')">Product</p>
 </div>
</template>
<script>
 export default{

 }
</script>
<style>

</style>

至此,全局混入大功告成,有心的读者也可以试试局部混入(主要用于后期代码维护)。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript WebSocket使用实例介绍(简明入门教程)
Apr 16 Javascript
jQuery插件EasyUI校验规则 validatebox验证框
Nov 29 Javascript
JavaScript重定向URL参数的两种方法小结
Oct 19 Javascript
require.js+vue开发微信上传图片组件
Oct 27 Javascript
使用JS实现气泡跟随鼠标移动的动画效果
Sep 16 Javascript
Bootstrap Table 删除和批量删除
Sep 22 Javascript
使用veloticy-ui生成文字动画效果
Feb 08 Javascript
通过vue提供的keep-alive减少对服务器的请求次数
Apr 01 Javascript
JavaScript惰性求值的一种实现方法示例
Jan 11 Javascript
原生js实现的移动端可拖动进度条插件功能详解
Aug 15 Javascript
layui监听单元格编辑前后交互的例子
Sep 16 Javascript
详解JavaScript数据类型和判断方法
Sep 04 Javascript
React中使用UEditor百度富文本的方法
Aug 22 #Javascript
VUE 全局变量的几种实现方式
Aug 22 #Javascript
详解使用VUE搭建后台管理系统(vue-cli更新至3.0)
Aug 22 #Javascript
基于vue.js中关于下拉框的值默认及绑定问题
Aug 22 #Javascript
微信小程序有旋转动画效果的音乐组件实例代码
Aug 22 #Javascript
vue2.0 下拉框默认标题设置方法
Aug 22 #Javascript
VUE中v-on:click事件中获取当前dom元素的代码
Aug 22 #Javascript
You might like
require(),include(),require_once()和include_once()的异同
2007/01/02 PHP
使用PHP导出Word文档的原理和实例
2013/10/21 PHP
PHP实现根据设备类型自动跳转相应页面的方法
2014/07/24 PHP
PHP中static关键字以及与self关键字的区别
2015/07/01 PHP
thinkphp autoload 命名空间自定义 namespace
2015/07/17 PHP
thinkphp验证码的实现(form、ajax实现验证)
2016/07/28 PHP
深入理解Yii2.0乐观锁与悲观锁的原理与使用
2017/07/26 PHP
PHP使用反向Ajax技术实现在线客服系统详解
2019/07/01 PHP
Nigma vs Liquid BO3 第一场2.14
2021/03/10 DOTA
在JQuery dialog里的服务器控件 事件失效问题
2010/12/08 Javascript
jquery1.5.1中根据元素ID获取元素对象的代码
2011/04/02 Javascript
node.js中的buffer.toJSON方法使用说明
2014/12/14 Javascript
jQuery超精致图片轮播幻灯片特效代码分享
2015/09/10 Javascript
利用VUE框架,实现列表分页功能示例代码
2017/01/12 Javascript
JavaScript字符串_动力节点Java学院整理
2017/06/27 Javascript
jsonp跨域获取数据的基础教程
2018/07/01 Javascript
koa2服务端使用jwt进行鉴权及路由权限分发的流程分析
2019/07/22 Javascript
VUE : vue-cli中去掉路由中的井号#操作
2020/09/04 Javascript
基于openlayers实现角度测量功能
2020/09/28 Javascript
python实现simhash算法实例
2014/04/25 Python
Python创建系统目录的方法
2015/03/11 Python
Python自定义进程池实例分析【生产者、消费者模型问题】
2016/09/19 Python
numpy.delete删除一列或多列的方法
2018/04/03 Python
如何真正的了解python装饰器
2020/08/14 Python
使用html5制作loading图的示例
2014/04/14 HTML / CSS
Foot Locker澳洲官网:美国运动服和鞋类零售商
2019/10/11 全球购物
说出数据连接池的工作机制是什么?
2013/04/19 面试题
Java的五个基础面试题
2016/02/26 面试题
工作中个人的自我评价
2013/12/31 职场文书
节能减耗标语
2014/06/21 职场文书
四风批评与自我批评发言稿
2014/10/14 职场文书
名人传读书笔记
2015/06/26 职场文书
2016年学校“3.12”植树节活动总结
2016/03/16 职场文书
详解Java实践之建造者模式
2021/06/18 Java/Android
javascript实现计算器功能详解流程
2021/11/01 Javascript
python井字棋游戏实现人机对战
2022/04/28 Python