requirejs、vue、vuex、vue-route的结合使用,您认为可行吗?
在五一节之前和一网友讨论前端技术时,对方提到vue、vue-route如果配合requirejs应用。当时的我没有想得很明白,也没能这位网友一个准确的回复,但我许诺于他五一研究后给他一个回复。本是一天的研究却被我搞成了研究了一周,这拖延症。。。
闲话少数,进入正题
一、示例代码说明
代码结构说明:
- modules(存放的为组件,主要是模板与Js对象分成两个文件来写)
- route:测试子路由的组件
- title:就是一个简单的显示文字的组件
- app.js:核心类,提供vue的创建、以前modules组件加载的方法等
- chart.js:模拟的一个业务模块
- index.html:页面文件
- layout.css:整体样式文件(测试require加入样式文件)
- main.js:requirejs的配置文件(也是入口文件)
丑陋的效果图:

此示例没有样式,只是为了验证require如何加载一个vue组件,以子路由的动态注入的能力,示例代码下载。
二、从.vue文件入手
一个.vue文件可以包含模板、Js类、样式(可以不要)等三块。但我们通过vue的官网可以知道,vue提供了compile对象方法,可以把模板编译成VNode。并且我们通过webpack打包后生成的文件可以看出模板与Js类是混淆在一起了。这也就说明vue的组件就是一个Js对象。如下图所示:
三、requirejs对vue、vuex和vue-route的引入
引入这三个都很容易,并将这三个注入到Vue对象也是相对简单的,难道的是需要解决动态注入向vue-route实例注入路由,以及vuex的动态加入一个数据模块的能力。好在这两点官网都给出了解决方案:
- vue-route如何动态注入路由
根据官网帮助文档说明,存在addRoutes方法,向路由实体动态注入路由 - vuex模块动态注入
也是根据官网帮助文档提示有registerModule方法实现。 - 实现的部分代码:
初始化Vue对象
apt.init = function(){
this.store = Object.create({
modules:{}
});
this.Vue.use(VueRouter);
this.Vue.use(Vuex);
this.router = new VueRouter();
this.store = new this.Vuex.Store(this.store);
}
首先提供一个init方法,对Vue对象进行一些初始化,也就是把Vuex、vue-route都注入到Vue对象中。在这里我把创建的vuex和vue-route的实例都放到this对象,方便后面提供给组件注册实使用。
创建Vue实例:
apt.createVue = function(){
this.vue = new this.Vue({
store: this.store,
router: this.router,
computed: {
childs: function(){
if(!this.$store.state.router) return null;
return this.$store.state.router.childs;
}
}
});
return this.vue;
}
只创建vue对象,没有进行mount。
为其他模块提供的上下文:
apt.createContext = function(){
return {
Vue: this.Vue,
router: this.router,
$vue: this.vue
};
}
四、如何通过require加载html和js方式的组件
从项目结构图中可以看出在modules文件夹中定义了两个组件,分别是:routet和title,而他们的模板则是一个html文件。以下是这类组件如何加载的代码:
apt.acquire = function(path){
var arrayPath;
if(!this.isArray(path)){
arrayPath = [path];
}else{
arrayPath = path;
}
var promise = this.dfd(function(dfd){
require(arrayPath,function(){
dfd.resolve(Array.prototype.slice.call(arguments));
},function(error){
dfd.reject(error);
});
}).promise();
return promise;
}
apt.createComponent = function(componentName){
//可以重载,读取.vue的文件
var path = this.$modulePrefix + componentName,
html = 'text!' + path + '/index.html',
js = path + '/index.js',
self = this;
var promise = this.acquire([html,js]);
promise.done(function(result){
var obj = result[1], content = result[0];
obj.template = content;
obj.__path__ = path;
self.$components.push(obj);
});
return promise;
}
说明: acquire:提供通过require加载JS或者是html等文件的方法,并返回一个promise,这样就方便调用者使用。 createComponet:会根据调用传入的名称在modules文件夹中找出对应的js和html文件,然后调用acquire加载组件。
五、main.js是这样引用的
提供注册全局组件方法
apt.registerGlobalComponents = function(componentNames){
var gloadComponet = componentNames, self = this;
var promises = gloadComponet.map(function(data,index){
return self.createComponent(data);
});
var dfd = this.dfd();
$.when.apply(null, promises).done(function(){
var _router = [];
self.$components.forEach(function(data,index){
self.Vue.component(data.name, data);
_router.push({
path: '/' + data.name,
component: data
});
});
self.router.addRoutes(_router); //全局注册都注册为路由
dfd.resolve(_router);
});
return dfd.promise();
}
main.js中的引用
var _app = app.createApp();
_app.registerGlobalComponents(['title', 'route']).done(function(){
var vue = _app.createVue();
var cxt = app.getVue().createContext();
var r = {
state: {
childs: []
},
mutations: {
childs: function(state, data){
state.childs = data;
}
},
actions: {
childs: function(state, data){
state.commit('childs', data);
}
}
}
vue.$store.registerModule('router', r);
vue.$mount('#app');
});
说明:
- 创建App的一个实例;
- 注册全局的组件:title、route;
- 注册完成后创建vue实例,并且向实例的vuex注入二级路由展示的模块
requirejs、vue、vuex、vue-route的结合使用,您认为可行吗?的更多相关文章
- vue vuex vue-rouert后台项目——权限路由(超详细简单版)
项目地址:vue-simple-template共三个角色:adan barbara carrie 密码全是:123456 adan 拥有 最高权限A 他可以看到 red , yellow 和 blu ...
- vue+vuex 回退定位到初始位置
先放出两张图(没错,你还在9012,做为一名资深设计师我唯一的技能点就是留白),简单说明下问题未做回退定位(从落地页回退,每次都回到A位置)想死啊有木有,每次都需要手动重新定位来选择,你大哥看到你做个 ...
- vuejs学习——vue+vuex+vue-router项目搭建(三)
前言 vuejs学习——vue+vuex+vue-router项目搭建(一) vuejs学习——vue+vuex+vue-router项目搭建(二) 为什么用vuex:组件之间的作用域独立,而组件之间 ...
- vuejs学习——vue+vuex+vue-router项目搭建(二)
前言 最近比较忙,所有第二章发布晚了,不好意思各位. vuejs学习——vue+vuex+vue-router项目搭建(一) 中我们搭建好了vue项目,我相信大家已经体验了vue其中的奥妙了,接下来我 ...
- vue+vuex构建单页应用
基本 构建工具: webpack 语言: ES6 分号:行首分号规则(行尾不加分好, [ , ( , / , + , - 开头时在行首加分号) 配套设施: webpack 全家桶, vue 全家桶 项 ...
- vue+vuex初入门
Vuex Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化. 解决问题: 传参的方法对于多层嵌 ...
- 我的音乐盒子(nodejs7 + koa2 + vue + vuex + vue-router)
你们知道的,nodejs对jser来说,是个好东西,快快的,自从接触nodejs后,总想弄点东西. 这弄个啥了,一天打开百度音乐盒,哟,自己弄一个如何了,好啊好啊. 后台: nodejs 7 + ko ...
- use vue vuex vue-router, not use webpack
vue,vuex,vue-router放在一起能做什么?不用webpack之类的打包工具使用他们是否可行?各位道友在初学vue时是否有这样的困惑.因为现代构建前端项目的一般模式是: 安装webapck ...
- [ABP开源项目]--vue+vuex+vue-router+EF的权限管理系统
好久没写文字了,当然大家也不期待嘛,反正看代码就行了. 演示网站 首先说下这个项目吧. 如标题一样是基于VUE+.NET开发的框架,也是群友一直吼吼吼要一个vue版本的ABP框架. 我们先来看看首页吧 ...
- [Vue] vuex进行组件间通讯
vue 组件之间数据传输(vuex) 初始化 store src/main.js import Vuex from "vuex"; Vue.use(Vuex); new Vue({ ...
随机推荐
- mapreduce项目中加入combiner
combiner相当于是一个本地的reduce,它的存在是为了减少网络的负担,在本地先进行一次计算再叫计算结果提交给reduce进行二次处理. 现在的流程为: 对于combiner我们有这些理解: M ...
- php八种常用函数
八种常用的数学函数: ① abs(x):求绝对值 ② ceil(x),floor(x):向上/下取最接近的整数 ③ cos(x),sin(x),tan(x):三角函数 ④ min(),max( ...
- 2018-2019-1 20189201 《LInux内核原理与分析》第九周作业
那一天我二十一岁,在我一生的黄金时代.我有好多奢望.我想爱,想吃,还想在一瞬间变成天上半明半暗的云.那一年我二十一岁,在我一生的黄金时代.我有好多想法.我思索,想象,我不知该如何行动,我想知道一个城市 ...
- leetcode刷题七<整数反转>
给出一个 位的有符号整数,你需要将这个整数中每位上的数字进行反转. 示例 : 输入: 输出: 示例 : 输入: - 输出: - 示例 : 输入: 输出: 假设我们的环境只能存储得下 32 位的有符号整 ...
- Loading Data into a Table;MySQL从本地向数据库导入数据
在localhost中准备好了一个test数据库和一个pet表: mysql> SHOW DATABASES; +--------------------+ | Database | +---- ...
- python爬取珞珈1号卫星数据
首先登录珞珈一号数据系统查询想要的数据 利用浏览器审查元素获取包含下载信息的源码 将最右侧的table相关的网页源码copy到剪切板备用 利用python下载数据 ## utf-8 import re ...
- Largest Rectangle in a Histogram [POJ2559] [单调栈]
题意一个围挡由n个宽度为1的长方形挡板下端对齐后得到,每个长方形挡板的高度为hi.我们把其抽象成一个图形,问这个图形中包含的面积最大的长方形是多大? 输入多行数据,每行第一个为n,后面n个数,代表hi ...
- socket error:10053
系统提示:10053,由于超时或其它失败,连接中止 服务端和客户端并没有出现连接错误或主动关闭连接 发生这个错误的原因往往是连接上了,但是长时间没有通信,所以连接被挂起了 防止的办法就是自己设计心跳包 ...
- React修改state(非redux)中数组和对象里边的某一个属性的值
在使用React时,会经常需要处理state里边设置的初始值以达到我们的实际需求,比如从接口获取到列表数据后要赋值给定义的列表初始值,然后数据驱动view视图进而呈现在我们眼前,这种最简单的赋值方式实 ...
- SpringAop注解实现日志的存储
一.介绍 1.AOP的作用 在OOP中,正是这种分散在各处且与对象核心功能无关的代码(横切代码)的存在,使得模块复用难度增加.AOP则将封装好的对象剖开,找出其中对多个对象产生影响的公共行为,并将其封 ...