使用requirejs管理vue組件代碼,有助于我們在實踐中更好的解耦和復用代碼。下面來看看如何使用requirejs寫vue組件。
首先我們需要配置requirejs,其中包含對vue和其他依賴庫路徑的配置:
require.config({
baseUrl: '/scripts',
paths: {
'vue': '//cdn.jsdelivr.net/npm/vue/dist/vue',
'jquery': '//cdn.bootcss.com/jquery/3.3.1/jquery.min',
'lodash': '//cdn.bootcss.com/lodash.js/4.17.11/lodash.min',
'text': '//cdn.bootcss.com/require-text/2.0.12/text.min',
'css': '//cdn.bootcss.com/require-css/0.1.10/css.min',
'components': '../components',
'templates': '../templates'
}
});
接下來是編寫vue組件的代碼,以一個簡單的計數器組件為例:
define(['vue', 'text!templates/counter.html'], function(Vue, counterTemplate) {
var Counter = Vue.extend({
template: counterTemplate,
data: function() {
return { count: 0 };
},
methods: {
increment: function() {
this.count++;
}
}
});
return Counter;
});
上述代碼中,我們引入了vue和計數器組件模板文件,使用Vue.extend方法創建一個組件構造函數,定義了組件的data屬性和increment方法,并將其暴露出去。
最后,在應用中引入該組件:
require(['vue', 'components/Counter'], function(Vue, Counter) {
new Vue({
el: '#app',
components: {
'counter': Counter
}
});
});
上述代碼中,我們通過RequireJS方式引入了vue和Counter組件,創建了一個Vue實例,將Counter組件注冊為全局組件,最后掛載到DOM元素上。現在我們就可以在應用中使用Counter組件了:
<div id="app">
<counter></counter>
</div>
以上就是使用RequireJS寫Vue組件的方法,通過RequireJS管理Vue組件代碼,可以讓我們更好地利用模塊化思想完成項目,同時提高代碼復用率和可維護性。
上一篇css寫圖片陰影