最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Vue之mixin全局的用法详解

来源:动视网 责编:小采 时间:2020-11-27 22:09:26
文档

Vue之mixin全局的用法详解

Vue之mixin全局的用法详解:先贴上官方定义。 个人觉得全局mixin就是给全部Vue文件添加一些公用的实例(方法,过滤器and so on) 使用场景:货币单位,时间格式。这些如果在用到的页面使用的话代码会重复的很多,所以在全局混入这些实例会减少代码量,可维护性也比较高。 ex: st
推荐度:
导读Vue之mixin全局的用法详解:先贴上官方定义。 个人觉得全局mixin就是给全部Vue文件添加一些公用的实例(方法,过滤器and so on) 使用场景:货币单位,时间格式。这些如果在用到的页面使用的话代码会重复的很多,所以在全局混入这些实例会减少代码量,可维护性也比较高。 ex: st

先贴上官方定义。

个人觉得全局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> 

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

文档

Vue之mixin全局的用法详解

Vue之mixin全局的用法详解:先贴上官方定义。 个人觉得全局mixin就是给全部Vue文件添加一些公用的实例(方法,过滤器and so on) 使用场景:货币单位,时间格式。这些如果在用到的页面使用的话代码会重复的很多,所以在全局混入这些实例会减少代码量,可维护性也比较高。 ex: st
推荐度:
标签: 使用 VUE 用法
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top