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 读取图片文件的大小
Jun 25 Javascript
JavaScript OOP类与继承
Nov 15 Javascript
js小数运算出现多位小数如何解决
Oct 08 Javascript
JavaScript是如何实现继承的(六种方式)
Mar 31 Javascript
JavaScript中的Array 对象(数组对象)
Jun 02 Javascript
vue + element-ui实现简洁的导入导出功能
Dec 22 Javascript
使用vue-router为每个路由配置各自的title
Jul 30 Javascript
微信小程序如何连接Java后台
Aug 08 Javascript
layui自己添加图片按钮并点击跳转页面的例子
Sep 14 Javascript
vue键盘事件点击事件加native操作
Jul 27 Javascript
Vue基于localStorage存储信息代码实例
Nov 16 Javascript
JavaScript使用canvas绘制坐标和线
Apr 28 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
967 个函式
2006/10/09 PHP
php数组总结篇(一)
2008/09/30 PHP
9段PHP实用功能的代码推荐
2014/10/14 PHP
Symfony2中被遗弃的getRequest()方法分析
2016/03/17 PHP
深入分析PHP优化及注意事项
2016/07/04 PHP
json简单介绍
2008/06/10 Javascript
javascript 面向对象的JavaScript类
2010/05/04 Javascript
用Jquery实现多级下拉框无刷新的联动
2010/12/22 Javascript
基于jquery实现的上传图片及图片大小验证、图片预览效果代码
2011/04/12 Javascript
js中使用DOM复制(克隆)指定节点名数据到新的XML文件中的代码
2011/07/27 Javascript
javascript数字格式化通用类 accounting.js使用
2012/08/24 Javascript
JS获取html对象的几种方式介绍
2013/12/05 Javascript
Angular使用 ng-img-max 调整浏览器中的图片的示例代码
2017/08/17 Javascript
Nodejs中crypto模块的安全知识讲解
2018/01/03 NodeJs
详解Webpack-dev-server的proxy用法
2018/09/08 Javascript
Vue Cli3 创建项目的方法步骤
2018/10/15 Javascript
创建nuxt.js项目流程图解
2020/03/13 Javascript
vscode自定义vue模板的实现
2021/01/27 Vue.js
[30:37]【全国守擂赛】第三周擂主赛 Dark Knight vs. Leopard Gaming
2020/05/04 DOTA
Python文档生成工具pydoc使用介绍
2015/06/02 Python
ansible作为python模块库使用的方法实例
2017/01/17 Python
django模型层(model)进行建表、查询与删除的基础教程
2017/11/21 Python
pytorch构建网络模型的4种方法
2018/04/13 Python
Python+Pandas 获取数据库并加入DataFrame的实例
2018/07/25 Python
使用 Python 在京东上抢口罩的思路详解
2020/02/27 Python
Python中猜拳游戏与猜筛子游戏的实现方法
2020/09/04 Python
详解python对象之间的交互
2020/09/29 Python
python switch 实现多分支选择功能
2020/12/21 Python
施华洛世奇天猫官方旗舰店:SWAROVSKI
2017/04/17 全球购物
真正的英国宝藏:Mappin & Webb
2019/05/05 全球购物
Brother加拿大官网:打印机、贴标机、缝纫机
2019/10/09 全球购物
职业生涯规划书范文
2014/03/10 职场文书
三关爱志愿服务活动方案
2014/08/17 职场文书
社区五一劳动节活动总结
2015/02/09 职场文书
支教个人总结
2015/03/04 职场文书
教你利用Selenium+python自动化来解决pip使用异常
2021/05/20 Python