Vue.js一个文件对应一个组件实践

网络编程 2021-07-04 20:01www.168986.cn编程入门
Vue.js实现"一个文件对应一个组件",无需webpack等工具,按需加载组件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

这方面官网给的示例是需要工具来编译的,nodejs又没有精力去学,只好曲线救国。VueJS的作者在另一个网站有一篇文章讲到可以用jQuery.getScript或RequireJS实现组件,却没有给示例,于是自己摸索出了一种方法。

用到的工具

vue.js --- 0.12.+ (需要0.12中async ponent支持)
require.js
text.js --- RequireJS text plugin

文件列表

index.html
index.js
p.js (组件在这里定义)
p.html (组件的模板)

实际上组件分成了js和html,html是模板内容,这里似乎与“一个文件对应一个组件”稍有不符,但如果模板内容比较多,这是有必要的,也更便于维护。 直接上代码。

p.html -- 组件模板

<h2>{{title}}</h2>
<p>{{content}}</p>
p.js -- 组件定义
define(['text!p.html'], function (temp) { // 在requirejs中定义一个模块,依赖为模板文本
 return {
 props: ['title', 'content'],
 template: temp
 }
});

至此,一个简单的模板就建好了。然后就是在VueJS中注册这个组件。

index.js

require.config({
 paths: { // 指定text.js和vue.js的路径,不需要.js后缀,详见RequireJS文档
 text: '../../../assets/requirejs/text',
 vue: '../../../assets/vue/vue'
 }
});

require(['vue'], function (Vue) { // 依赖vue.js
 Vue.ponent('p', function (resolve) { // 注册一个异步组件
 require(['p'], function (p) { // 因为我们要按需加载组件,require(['p'])必须在function里
 resolve(p)
 })
 });
 new Vue({
 el: 'body'
 });

 //new Vue({
 // el: 'body',
 // ponents: {
 // p: function (resolve) {
 // require(['p'], function (p) {
 // resolve(p)
 // })
 // }
 // }
 / 

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by