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


Posted in Javascript onOctober 27, 2016

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

用到的工具:

vue.js --- 0.12.+ (需要0.12中async component支持)
require.js
text.js --- RequireJS text plugin https://github.com/requirejs/text

文件列表

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

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

comp.html -- 组件模板

<h2>{{title}}</h2>
<p>{{content}}</p>
comp.js -- 组件定义
define(['text!comp.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.component('comp', function (resolve) { // 注册一个异步组件
 require(['comp'], function (comp) { // 因为我们要按需加载组件,因此require(['comp'])必须在function里
 resolve(comp)
 })
 });
 new Vue({
 el: 'body'
 });

 //new Vue({
 // el: 'body',
 // components: {
 // comp: function (resolve) {
 // require(['comp'], function (comp) {
 // resolve(comp)
 // })
 // }
 // }
 //});
});

index.html

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title></title>
</head>
<body>

<component is="comp" title="我是一个组件" content="fjkldsjfkldjsklgjks"></component>

<script data-main="index" src="../../../assets/require.js"></script>

</body>
</html>

运行代码,把<component>注释掉就能看到区别。

如果组件比较多,注册组件就会很繁琐,因此可以把这部分提炼出来。

改进后的index.js

require.config({
 paths: {
 text: '../../../assets/requirejs/text',
 vue: '../../../assets/vue/vue'
 }
});

function conponent(name) {
 return function (resolve, reject) {
 require([name], function (comp) {
 resolve(comp)
 })
 }
}

require(['vue'], function (Vue) {
 Vue.component('comp', conponent('comp'));
 Vue.component('comp2', conponent('comp2'));

 new Vue({
 el: 'body'
 });
});

至此。

本文已被整理到了《Vue.js前端组件学习教程》,欢迎大家学习阅读。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
cloudgamer出品ImageZoom 图片放大效果
Apr 01 Javascript
用js小类库获取浏览器的高度和宽度信息
Jan 15 Javascript
从阶乘函数对比Javascript和C#的异同
May 31 Javascript
jQuery实现可用于博客的动态滑动菜单
Mar 09 Javascript
jQuery中常用的遍历函数用法实例总结
Sep 01 Javascript
jQuery实现ctrl+enter(回车)提交表单
Oct 19 Javascript
AngularJS自定义插件实现网站用户引导功能示例
Nov 07 Javascript
基于JS实现的随机数字抽签实例
Dec 08 Javascript
DropDownList控件绑定数据源的三种方法
Dec 24 Javascript
vue页面使用阿里oss上传功能的实例(一)
Aug 09 Javascript
关于JavaScript语句后面的分号问题
Dec 07 Javascript
在vue-cli搭建的项目中增加后台mock接口的方法
Apr 26 Javascript
JavaScript实现类似拉勾网的鼠标移入移出效果
Oct 27 #Javascript
node.js文件上传处理示例
Oct 27 #Javascript
Vue.js表单控件实践
Oct 27 #Javascript
vue实现可增删查改的成绩单
Oct 27 #Javascript
vuex实现简易计数器
Oct 27 #Javascript
微信小程序  生命周期详解
Oct 27 #Javascript
require.js+vue开发微信上传图片组件
Oct 27 #Javascript
You might like
分页显示Oracle数据库记录的类之一
2006/10/09 PHP
获取php页面执行时间,数据库读写次数,函数调用次数等(THINKphp)
2013/06/03 PHP
php数组操作之键名比较与差集、交集赋值的方法
2014/11/10 PHP
php打包压缩文件之ZipArchive方法用法分析
2016/04/30 PHP
PHP PDOStatement::fetchAll讲解
2019/01/31 PHP
通过JS 获取Mouse Position(鼠标坐标)的代码
2009/09/21 Javascript
Jquery实现图片放大镜效果的思路及代码(自写)
2013/10/18 Javascript
javascript打印html内容功能的方法示例
2013/11/28 Javascript
jQuery实现当按下回车键时绑定点击事件
2014/01/28 Javascript
javascript连续赋值问题
2015/07/08 Javascript
原生ajax处理json格式数据的实例代码
2016/12/25 Javascript
jQuery基于ajax方式实现用户名存在性检查功能示例
2017/02/10 Javascript
JavaScript在控件上添加倒计时功能的实现代码
2017/07/04 Javascript
移动端效果之Swiper详解
2017/10/09 Javascript
浅谈JS 数字和字符串之间相互转化的纠纷
2017/10/20 Javascript
使用pkg打包ThinkJS项目的方法步骤
2019/12/30 Javascript
js的Object.assign用法示例分析
2020/03/05 Javascript
JavaScript数组排序功能简单实现
2020/05/14 Javascript
vue点击Dashboard不同内容 跳转到同一表格的实例
2020/11/13 Javascript
跟老齐学Python之复习if语句
2014/10/02 Python
Python如何生成树形图案
2018/01/03 Python
python多维数组切片方法
2018/04/13 Python
Python反射和内置方法重写操作详解
2018/08/27 Python
对Pandas MultiIndex(多重索引)详解
2018/11/16 Python
Python调用shell命令常用方法(4种)
2020/05/11 Python
html+css实现自定义图片上传按钮功能
2019/09/04 HTML / CSS
html5 Canvas画图教程(1)—画图的基本常识
2013/01/09 HTML / CSS
使用html2canvas.js实现页面截图并显示或上传的示例代码
2018/12/18 HTML / CSS
什么是聚集索引和非聚集索引
2012/01/17 面试题
Windows和Linux动态库应用异同
2016/04/17 面试题
农村婚礼证婚词
2014/01/08 职场文书
房地产营销策划方案
2014/02/08 职场文书
工会趣味活动方案
2014/08/18 职场文书
微信早安问候语
2015/11/10 职场文书
mysql如何能有效防止删库跑路
2021/10/05 MySQL
MySQL使用IF语句及用case语句对条件并结果进行判断 
2022/09/23 MySQL