当前仓库属于暂停状态,部分功能使用受限,详情请查阅 仓库状态说明
1 Star 0 Fork 39

ylmotol7/Vue-rap
暂停

forked from 藤之内/Vue-rap 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
rap.1.0.1.js 21.67 KB
一键复制 编辑 原始数据 按行查看 历史
藤之内 提交于 2018-03-19 10:14 . v-link.back
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682
/* vue-rap v1.0.0 | (c) 2018 by tengzhinei */
(function webpackUniversalModuleDefinition(root, factory) {
if(typeof exports === 'object' && typeof module === 'object')
module.exports = factory();
else if(typeof define === 'function' && define.amd)
define([], factory);
else if(typeof exports === 'object')
exports["Rap"] = factory();
else
root["Rap"] = factory();
})(this, function() {
var viewLines={
};
var routers={};
function urlJoin(base,url) {
if(url.indexOf('/')==0){
return url;
}
if(!(url.indexOf('/')>-1&&url.indexOf('.')>-1)){
return base+url;
}
var p=base.split("/");
p.pop();
p.pop();
var pre=[];
while(url.indexOf('../')==0){
url= url.replace("../","");
pre.push(p.pop())
}
return pre.join("/")+"/"+url;
}
function loadLayoutAndRely(url,rely,layout) {
if(rely&&rely.length>0){
for(var i=0;i<rely.length;i++){
Rap.loadMod(urlJoin(url,rely[i]));
}
}
if(layout){
Rap.loadMod(layout);
}
}
function evalScript(modUrl,url,modName,style,template,script) {
script="(function(url,name,style,template){\n if(Rap.debug){console.log('模块加载: '+modName);}"+script+";\nRap.$create(url,name,style,template);\n})(url,modName,style,template)\n";
if(Rap.debug){
script+="//@ sourceURL="+modUrl;
}
eval(script);
}
function evalJS(url,script) {
if(Rap.debug){
script+="//@ sourceURL="+url;
}
eval(script);
}
function addCss(id,content) {
var style = document.createElement('style');
style.type = 'text/css';
style.id=id;
style.innerHTML=content;
document.getElementsByTagName('HEAD').item(0).appendChild(style);
}
var layoutAndRely=[];
var compVersion={};
var preMod=[];
var preModLoading=false;
function v_link_click(event,m) {
var el=event.target;
var link=el.getAttribute("rap-link");
var replace=el.getAttribute("rap-replace");
var back=el.getAttribute("rap-back");
if(back=='true'){
Rap.back();
return;
}
var arg=el.getAttribute("rap-arg");
Rap.go(link,replace=='true');
}
var Rap={
config:function (config) {
config=Object.assign({
debug:false,
default_page:'',
app_version:1
},config);
Rap.debug = config.debug;
if(!config.default_page){
document.write("请配置默认页面default_page");
return;
}
Rap.default_page=config.default_page;
Rap.appVersion(config.app_version);
if(config.comp_version){
for(var key in config.comp_version){
Rap.compVersion(key,config.comp_version[key]);
}
}
if(config.css){
Rap.loadCss(config.css);
}
if(config.script){
Rap.loadScript(config.script);
}
if(!window.Vue){
document.write("请在script配置Vue对应的文件路径");
return;
}
Rap.install(Vue);
},
app:function (app) {
if(!app){
app={}
}
if(!app.el){
app.el="#app";
}
if(!app.mixins){
app.mixins=[];
}
app.mixins.push(Rap.MainView);
new Vue(app);
},
go:function (page,replace) {
if(replace==null){
replace=false;
}
if(replace){
history.replaceState(null,page,"#"+page);
Rap.onhashchange();
}
else{
location.href="#"+page;
}
},
replace:function (page) {
Rap.go(page,true);
},
back:function () {
history.back();
},
install:function (Vue) {
Vue.directive('link', {
bind: function (el, binding, vnode) {
el.setAttribute("rap-link", binding.value);
var modifiers=binding.modifiers;
if(modifiers.replace){
el.setAttribute("rap-replace", 'true');
}
if(modifiers.back){
el.setAttribute("rap-back", 'true');
}
if(binding.arg){
el.setAttribute("rap-arg", binding.arg);
}
if(el.addEventListener) {
el.addEventListener('click',v_link_click,false);
}
//ie使用attachEvent,来添加事件
else {
el.attachEvent("onclick",v_link_click);
}
},
update:function (el, binding, vnode) {
el.setAttribute("rap-link", binding.value);
},unbind:function (el, binding, vnode) {
if(el.removeEventListener){
el.removeEventListener("click",v_link_click,false);
}else{
el.detachEvent("click",v_link_click);
}
}
});
Rap.init();
},
default_page:'',
debug:false,
RapAppVersion:1,
global_router:{
query:{},
search:[],
page:'',
hash:''
},
baseUrl:"",
isReady:false,
$pageDefine:null,
loadScript:function (url) {
if(url instanceof Array){
for(var i=0;i<url.length;i++){
Rap.loadScript(url[i]);
}
}else{
var content=localStorage.getItem(url);
if(!Rap.debug&&content){
evalJS(url,content);
return true;
}else{
var xhr;
if (window.XMLHttpRequest) {
xhr = new XMLHttpRequest();//W3C
} else {
xhr = new ActiveXObject('MicroSoft.XMLHTTP');//IE
}
xhr.open('get', url, false);
xhr.send(null);
if (xhr.status == 200) {
content=xhr.responseText;
localStorage.setItem(url,content);
evalJS(url,content);
return true;
}
}
return true;
}
},
loadCss:function (url) {
if(url instanceof Array){
for(var i=0;i<url.length;i++){
Rap.loadCss(url[i]);
}
}else{
var content=localStorage.getItem(url);
if(!Rap.debug&&content){
addCss(url,content);
return true;
}else{
var xhr;
if (window.XMLHttpRequest) {
xhr = new XMLHttpRequest();//W3C
} else {
xhr = new ActiveXObject('MicroSoft.XMLHTTP');//IE
}
xhr.open('get', url, false);
xhr.send(null);
if (xhr.status == 200) {
content=xhr.responseText;
localStorage.setItem(url,content);
addCss(url,content);
return true;
}
}
return true;
}
},
compVersion:function(mod,version){
compVersion[mod]=version;
},
define:function () {
var layout=null;
var rely=null;
var config=null;
if(arguments.length>2){
layout=arguments[0];
rely=arguments[1];
config=arguments[2]
}else if(arguments.length>1){
rely=arguments[0];
config=arguments[1]
}else{
config=arguments[0];
}
this.$pageDefine={layout:layout,
rely:rely,
config:config};
},
appVersion:function (version) {
Rap.RapAppVersion=version;
var rapAppVersion=localStorage.getItem('RapAppVersion');
if(rapAppVersion&&rapAppVersion!=Rap.RapAppVersion){
localStorage.clear();
}
localStorage.setItem('RapAppVersion',Rap.RapAppVersion);
},
init:function () {
Rap.isReady=true;
localStorage.setItem('RapAppVersion',Rap.RapAppVersion);
if(layoutAndRely.length>0){
for (var index in layoutAndRely){
var param=layoutAndRely[index];
loadLayoutAndRely(param.url,param.rely,param.layout);
}
}
Rap.onhashchange();
},
$create:function (url,name,style,template) {
var modName=name;
var layout=this.$pageDefine.layout;
if(layout){
layout=urlJoin(url,layout);
}
var rely=this.$pageDefine.rely;
var config=this.$pageDefine.config;
config.template=template;
if(layout){
viewLines[modName]=layout.split('/').join('_');
}
var childMixin = {
data:function () {
return {
router:Rap.global_router,
RapViews:RapShareData.RapViews,
childView:null
};
},
watch: {
'router':{
handler: function () {
var init = this.$options.init;
if(init){
init.apply(this,[Rap.global_router.query,Rap.global_router.search]);
}
},
deep: true
},'RapViews.index':function () {
this.$options.RapViews.apply(this);
}
},
RapViews:function () {
var index=-1;
for(var i=0;i<this.RapViews.items.length;i++){
var name=this.RapViews.items[i];
if(name==modName){
index=i;
}
}
if(index+1<this.RapViews.items.length){
this.childView=this.RapViews.items[index+1];
}
},
beforeCreate:function () {
},
created: function () {
if(style){
var el=document.createElement('style');
el.id=modName;
el.innerText=style;
window.document.head.append(el);
}
this.$options.RapViews.apply(this);
},
activated:function () {
var el=document.getElementById(modName);
if(style&&!el){
el=document.createElement('style');
el.id=modName;
el.innerText=style;
window.document.head.append(el)
}
},
deactivated:function () {
var el=document.getElementById(modName);
if(el){
el.parentElement.removeChild(el);
}
},
mounted:function () {
var init = this.$options.init;
if(init){
init.apply(this,[Rap.global_router.query,Rap.global_router.search]);
}
},
destroyed:function () {
var el=document.getElementById(modName);
if(el){
el.parentElement.removeChild(el);
}
},
methods: {
}
};
if(!config.mixins){
config.mixins=[];
}
config.mixins.push(childMixin);
Vue.component(modName, config);
if(Rap.isReady){
loadLayoutAndRely(url,rely,layout);
}else{
layoutAndRely.push({
'url': url,
'rely':rely,
'layout':layout
})
}
delete Rap.$pageDefine;
},
loadUrl:function(url) {
var path=url.split('/');
var m=[];
for(var i=0;i<path.length;i++){
var item=path[i];
if(!(parseInt(item)+""==item||item.indexOf('@')==0)){
m.push(item);
}
}
path=m;
Rap.global_router.page=path.join('/');
var as=routers[ Rap.global_router.page];
if(as){
if(isFunction(as)){
as(Rap.global_router.query,Rap.global_router.search);
}else{
Rap.global_router.page=as;
}
return;
}
var modName=Rap.global_router.page.split('/').join('_');
if(Vue.component(modName)){
Rap.onViewChangeCallBack(modName);
}else{
this.loadMod(Rap.global_router.page);
Rap.onViewChangeCallBack(modName);
}
},
/**
* 预加载模块 异步队列加载的
*/
preComp:function (url) {
if(url instanceof Array){
for(var i=0;i<url.length;i++){
var u=url[i];
var loadU=u;
u=u.substr(u.indexOf('/')==0?1:0);
var path=u.split('/');
var modName=path.join('_');
if(Vue.component(modName)){
continue;
}
preMod.push(loadU);
}
}else{
url=url.substr(url.indexOf('/')==0?1:0);
var path=url.split('/');
var modName=path.join('_');
if(Vue.component(modName)){
return;
}
preMod.push(url);
}
if(preMod.length==0||preModLoading)return true;
preModLoading=true;
setTimeout(function () {
while(preMod.length>0){
var url= preMod.shift();
Rap.loadMod(url);
}
preModLoading=false;
},100);
},
/**
* 同步加载模块
* @param url
*/
loadMod:function (url) {
url=url.substr(url.indexOf('/')==0?1:0);
var modUrl=this.baseUrl+url;
var path=url.split('/');
var modName=path.join('_');
path.pop();
url=path.join("/")+"/";
if(Vue.component(modName)){
return;
}
var key=modUrl+'.ver';
var key_content=modUrl+'.json';
var version=Rap.RapAppVersion;
if(compVersion[modUrl]){
version=compVersion[modUrl];
}
if(!Rap.debug){
var content= localStorage.getItem(key);
if(content){
if(content==version){
content=localStorage.getItem(key_content);
var json=JSON.parse(content);
evalScript(modUrl+".js",url,modName,json.style,json.template,json.script);
return;
}else{
localStorage.removeItem(key_content);
}
}
}
var xhr;
if (window.XMLHttpRequest) {
xhr = new XMLHttpRequest();//W3C
} else {
xhr = new ActiveXObject('MicroSoft.XMLHTTP');//IE
}
xhr.open('get', modUrl+'.html?version='+version, false);
xhr.send(null);
if (xhr.status == 200) {
var el=document.createElement('div');
el.innerHTML=xhr.responseText;
var style="";
var template="";
var script="";
for(var i=0;i<el.children.length;i++) {
var child = el.children[i];
if (child.tagName == "STYLE"){
style=child.innerText;
}
if (child.tagName == "TEMPLATE"){
template=child.innerHTML;
}
if (child.tagName == "SCRIPT"){
script=child.innerHTML;
}
}
var lc={
style:style,
template:template,
script:script
};
localStorage.setItem(key,version);
localStorage.setItem(key_content,JSON.stringify(lc));
evalScript(modUrl+".js",url,modName,style,template,script);
} else {
console.log('url:'+modUrl+" get error" + xhr.status + 'message:' + xhr.statusText)
}
},
$query:function () {
var hash=window.location.hash;
var query={};
if(hash.indexOf('?')>-1){
hash=hash.substr(hash.indexOf('?')+1);
var qs=hash.split('&');
for(var i=0;i<qs.length;i++){
var q=qs[i];
if(!q)continue;
var kv=q.split('=');
query[kv[0]]=kv[1];
}
}
return query;
},
$search:function (ids) {
var hash=window.location.hash;
hash=hash.substr(hash.indexOf('/')==1?2:1);
if(hash.indexOf('?')>-1){
hash=hash.substr(0,hash.indexOf('?'));
}
var path=hash.split('/');
var m=[];
var args=arguments;
for(var i=0;i<path.length;i++){
var item=path[i];
if(parseInt(item)+""==item){
m.push(item);
}else if(item.indexOf('@')==0){
m.push(item.substr(1));
}
}
if(args.length>0){
var result={};
for(i=0;i<args.length;i++){
result[args[i]]=m[i];
}
return result;
}
return m;
},
onhashchange:function () {
var hash=window.location.hash;
if(!hash&&Rap.default_page){
window.location.href="#"+Rap.default_page;
return;
}
hash=hash.substr(hash.indexOf('/')==1?2:1);
Rap.global_router.hash=hash;
if(hash.indexOf('?')>-1){
hash=hash.substr(0,hash.indexOf('?'));
}
for(var key in Rap.global_router.query){
delete Rap.global_router.query[key]
}
var query=Rap.$query();
for(var key in query){
var value=query[key];
if(parseInt(value)+""==value){
value=parseInt(value);
}
Vue.set(Rap.global_router.query,key,value);
}
Rap.global_router.search.length=0;
var search=Rap.$search();
for(var index in search){
var value=search[index];
if(parseInt(value)+""==value){
value=parseInt(value);
}
Rap.global_router.search.push(value);
}
Rap.loadUrl(hash);
},
onViewChangeCallBack:null,
onViewChange: function(fun) {
this.onViewChangeCallBack=fun;
},
router:function (hash,as) {
hash=hash.substr(hash.indexOf('/')==0?1:0);
as=as.substr(as.indexOf('/')==0?1:0);
routers[hash]=as;
}
};
var RapShareData= {
RapViews:{
index:1,
items:[]
},
childView:''
};
Rap.MainView={
data: function() {
return RapShareData;
},
watch: {
'RapViews.index':{
handler:function () {
this.childView=this.RapViews.items[0];
},deep:true
}
},
created:function () {
if(this.RapViews.items.length>0){
this.childView=this.RapViews.items[0];
}
}
};
function currentItems(items,view) {
items.push(view);
var layout=viewLines[view];
if(layout){
currentItems(items,layout);
}
}
Rap.onViewChange(function (view) {
var items=[];
currentItems(items,view);
items=items.reverse();
RapShareData.RapViews.items=items;
RapShareData.RapViews.index++;
});
window.addEventListener("popstate", Rap.onhashchange, false);
return Rap;
});
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
JavaScript
1
https://gitee.com/ylmotol7/Vue-rap.git
git@gitee.com:ylmotol7/Vue-rap.git
ylmotol7
Vue-rap
Vue-rap
master

搜索帮助