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 相关文章推荐
slice函数的用法 之不错的应用
Dec 29 Javascript
Javascript在IE或Firefox下获取鼠标位置的代码
Dec 18 Javascript
js 遍历json返回的map内容示例代码
Oct 29 Javascript
JS 实现BASE64_ENCODE和BASE64_DECODE(实例代码)
Nov 13 Javascript
小心!AngularJS结合RequireJS做文件合并压缩的那些坑
Jan 09 Javascript
动态加载JavaScript文件的两种方法
Apr 22 Javascript
JavaScript浏览器对象之一Window对象详解
Jun 03 Javascript
jsp 网站引入外部css或者js失效问题解决
Oct 31 Javascript
mint-ui 时间插件使用及获取选择值的方法
Feb 09 Javascript
微信小程序解析富文本过程详解
Jul 13 Javascript
JavaScript实现10秒后再次获取验证码
Dec 02 Javascript
Javascript设计模式之原型模式详细
Oct 05 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
php读取文件内容至字符串中,同时去除换行、空行、行首行尾空格(Zjmainstay原创)
2012/07/31 PHP
关于PHP递归算法和应用方法介绍
2013/04/15 PHP
PHP调用.NET的WebService 简单实例
2015/03/27 PHP
Laravel学习教程之IOC容器的介绍与用例
2017/08/15 PHP
PHP7创建COOKIE和销毁COOKIE的实例方法
2020/02/03 PHP
可以显示单图片,多图片ajax请求的ThickBox3.1类下载
2007/12/23 Javascript
JQuery 学习笔记 选择器之二
2009/07/23 Javascript
jQuery创建插件的代码分析
2011/04/14 Javascript
JavaScript建立一个语法高亮输入框实现思路
2013/02/26 Javascript
jQuery Masonry瀑布流插件使用详解
2014/11/17 Javascript
javascript判断数组内是否重复的方法
2015/04/21 Javascript
PhantomJS快速入门教程(服务器端的 JavaScript API 的 WebKit)
2015/08/06 Javascript
js获取url传值的方法
2015/12/18 Javascript
Bootstrap多级导航栏(级联导航)的实现代码
2016/03/08 Javascript
JS常用字符串方法(推荐)
2021/01/15 Javascript
基于HTML5+JS实现本地图片裁剪并上传功能
2017/03/24 Javascript
前端MVVM框架解析之双向绑定
2018/01/24 Javascript
Vue.js单向绑定和双向绑定实例分析
2018/08/14 Javascript
最适应的vue.js的form提交涉及多种插件【推荐】
2018/08/27 Javascript
vue动画效果实现方法示例
2019/03/18 Javascript
Nodejs监听日志文件的变化的过程解析
2019/08/04 NodeJs
es6函数之尾递归用法实例分析
2020/04/25 Javascript
[02:23]完美世界全国高校联赛街访DOTA2第一期
2019/11/28 DOTA
python使用两种发邮件的方式smtp和outlook示例
2017/06/02 Python
用Python实现随机森林算法的示例
2017/08/24 Python
当当网官方旗舰店:中国图书销售夺金品牌
2018/04/02 全球购物
应届生骨科医生求职信
2013/10/31 职场文书
出纳岗位职责范本
2013/12/01 职场文书
产品发布会策划方案
2014/05/12 职场文书
优秀班主任推荐材料
2014/12/17 职场文书
学生退学证明
2015/06/23 职场文书
《植树问题》教学反思
2016/03/03 职场文书
2019自荐信该如何写呢?
2019/07/05 职场文书
创业计划书之书店
2019/09/10 职场文书
win10键盘驱动怎么修复?Win10键盘驱动修复小技巧
2022/04/06 数码科技
spring IOC容器的Bean管理XML自动装配过程
2022/05/30 Java/Android