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 相关文章推荐
extjs grid设置某列背景颜色和字体颜色的实现方法
Sep 06 Javascript
input链接页面、打开新网页等等的具体实现
Dec 30 Javascript
在JS数组特定索引处指定位置插入元素
Jul 27 Javascript
实例讲解jQuery中对事件的命名空间的运用
May 24 Javascript
ECHO.js 纯javascript轻量级延迟加载的实例代码
May 24 Javascript
Ajax+FormData+javascript实现无刷新表单信息提交
Oct 24 Javascript
完美解决jQuery fancybox ie 无法显示关闭按钮的问题
Nov 29 Javascript
underscore之Chaining_动力节点Java学院整理
Jul 10 Javascript
JS实现分页浏览横向图片(类轮播)实例代码
Nov 06 Javascript
解决Layui选择全部,换页checkbox复选框重新勾选的问题方法
Aug 14 Javascript
详解 微信小程序开发框架(MINA)
May 17 Javascript
jQuery实现鼠标放置名字上显示详细内容气泡提示框效果的方法分析
Apr 04 jQuery
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
php 清除网页病毒的方法
2008/12/05 PHP
PHP支持多种格式图片上传(支持jpg、png、gif)
2011/11/03 PHP
PHP spl_autoload_register实现自动加载研究
2011/12/06 PHP
php中的filesystem文件系统函数介绍及使用示例
2014/02/13 PHP
Codeigniter注册登录代码示例
2014/06/12 PHP
PHP单例模式定义与使用实例详解
2017/02/06 PHP
Jquery焦点与失去焦点示例应用
2014/06/10 Javascript
JavaScript中遍历对象的property的3种方法介绍
2014/12/30 Javascript
JQUERY实现网页右下角固定位置展开关闭特效的方法
2015/07/27 Javascript
JavaScript知识点总结(六)之JavaScript判断变量数据类型
2016/05/31 Javascript
Angular2 环境配置详细介绍
2016/09/21 Javascript
Node.js利用Net模块实现多人命令行聊天室的方法
2016/12/23 Javascript
微信小程序 支付功能实现PHP实例详解
2017/05/12 Javascript
详解vue模拟加载更多功能(数据追加)
2017/06/23 Javascript
vue 项目常用加载器及配置详解
2018/01/22 Javascript
详解vue 计算属性与方法跟侦听器区别(面试考点)
2018/04/23 Javascript
Vue组件内部实现一个双向数据绑定的实例代码
2019/04/04 Javascript
vue elementui el-form rules动态验证的实例代码详解
2019/05/23 Javascript
nuxt静态部署打包相对路径操作
2020/11/06 Javascript
Element el-button 按钮组件的使用详解
2021/02/01 Javascript
python和ruby,我选谁?
2017/09/13 Python
Python学习小技巧总结
2018/06/10 Python
python提取具有某种特定字符串的行数据方法
2018/12/11 Python
Python 按字典dict的键排序,并取出相应的键值放于list中的实例
2019/02/12 Python
Python GUI库PyQt5样式QSS子控件介绍
2020/02/25 Python
Python代码一键转Jar包及Java调用Python新姿势
2020/03/10 Python
浅谈keras中Dropout在预测过程中是否仍要起作用
2020/07/09 Python
Airbnb爱彼迎官网:成为爱彼迎房东,赚取收入
2019/03/14 全球购物
英国工作场所设备购买网站:Slingsby
2019/05/03 全球购物
办加油卡单位介绍信
2014/01/09 职场文书
幼儿园教师请假制度
2014/01/16 职场文书
法院反腐倡廉心得体会
2014/09/09 职场文书
民事赔偿协议书
2014/11/02 职场文书
销售经理岗位职责范本
2015/04/02 职场文书
党性教育心得体会(共6篇)
2016/01/21 职场文书
利用Apache Common将java对象池化的问题
2022/06/16 Servers