使用带有Vuejs的mixins

时间:2016-09-06 21:57:14

标签: javascript vue.js mixins

我目前正在学习如何使用Vuejs开发应用程序。我有一个main.js文件,其中包含用于设置Vue.js的代码。我用新文件api.js创建了一个新目录/ mixins。我想将它用作mixin,以便每个组件都可以使用函数来访问我的api。但我不知道该怎么做。

这是我的/mixins/api.js文件:

export default{
  callapi() {
    alert('code to call an api');
  },
};

这是我的main.js文件:

import Vue from 'vue';
import VueRouter from 'vue-router';
import VueResource from 'vue-resource';

import { configRouter } from './routeconfig';

import CallAPI from './mixins/api.js';

// Register to vue
Vue.use(VueResource);
Vue.use(VueRouter);


// Create Router
const router = new VueRouter({
  history: true,
  saveScrollPosition: true,
});

// Configure router
configRouter(router);


// Go!
const App = Vue.extend(
  require('./components/app.vue')
);

router.start(App, '#app');

如何以正确的方式包含我的mix,以便每个组件都可以访问callapi()函数?

2 个答案:

答案 0 :(得分:11)

如果您想在特定的组件上使用mixin,而不是所有组件,您可以这样做:

mixin.js

export default {
  methods: {
    myMethod() { .. }
  }
}

component.vue

import mixin from 'mixin';

export default {
  mixins: [ mixin ]
}

您可能考虑的另一件事是使用组件扩展设计模式,即创建基本组件,然后从子组件继承。如果您有许多组件共享许多选项并且也可能继承模板,那么它会更复杂但保持代码DRY。

如果您有兴趣,我已经写了on my blog

答案 1 :(得分:9)

您可以使用Vue.mixin

全局应用mixin
api.js
------

export default {
  methods: {
    callapi() {};
  }
}

main.js
-------

import CallAPI from './mixins/api.js';

Vue.mixin(CallAPI)

正如documentation所述,您应该谨慎使用它:

  

稀疏地使用全局mixins,因为它会影响每个创建的Vue实例,包括第三方组件。