From f89d4a823e8fcd72d03dc00b2ca5c4e2f71a6351 Mon Sep 17 00:00:00 2001
From: tmplink <45227137+tmplink@users.noreply.github.com>
Date: Tue, 18 Dec 2018 22:46:22 +0800
Subject: [PATCH] =?UTF-8?q?=E6=9B=B4=E6=96=B0=E5=88=B0=20v1.4?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
新增两个功能
---
CHANGE.md | 5 +++++
README.md | 18 +++++++++++++++++-
domloader.js | 24 ++++++++++++++++++++----
3 files changed, 42 insertions(+), 5 deletions(-)
diff --git a/CHANGE.md b/CHANGE.md
index 99ee027..976b420 100644
--- a/CHANGE.md
+++ b/CHANGE.md
@@ -1,3 +1,8 @@
+# 版本 v1.4
+
+* 新增了 domloader.version 参数,此参数用于设置所有资源的版本信息,如果你的静态资源已经修改,但是浏览器极有可能缓存,那么通过这个参数来设置版本号可以很好地解决缓存的问题。
+* 新增了 domloader.onload 参数,此参数可以设置一系列回调(队列),当domloader完成所有资源加载时,执行此回调队列。
+
# 版本 v1.3
* 新增了 domloader.root 参数,此参数用于设置一个项目根目录地址,如果当前项目放置在子目录,那么请设置此参数,可以确保正确加载资源文件。
diff --git a/README.md b/README.md
index 33b5c72..e52ff9c 100644
--- a/README.md
+++ b/README.md
@@ -88,13 +88,29 @@ domloader.css(path);
domloader.js(path);
```
-设置网站根目录
+设置网站根目录
如果你要把整个前端项目放在子目录,那么这个设置可以确保正确加载资源。
一旦设置了此参数,每次加载时都会在地址前附加此参数。
```javascript
domloader.root = 'https://yourwebsite.com/subdir/';
```
+设置资源文件版本号
+可以解决由于浏览器缓存导致的资源更新不及时问题。
+一旦设置了此参数,每次加载时都会在地址后附加此参数。
+```javascript
+domloader.version = 'v1.0';
+```
+
+设置加载完成后的回调操作
+有一些操作必须要在所有资源加载完成之后进行。
+onload方法允许你设置一系列回调,将会在domloader加载完所有资源文件后启动这个回调。
+```javascript
+domloader.onload(
+ function(){ xxx.xxx(); }
+);
+```
+
设置加载页面的icon
如果你不设置这个,那么在加载时只会显示进度条
```javascript
diff --git a/domloader.js b/domloader.js
index 122b0bf..bdfe617 100644
--- a/domloader.js
+++ b/domloader.js
@@ -1,6 +1,6 @@
/*!
* domloader.js
- * v1.3
+ * v1.4
* https://github.com/tmplink/domloader/
*
* Licensed GPLv3 © TMPLINK STUDIO
@@ -8,19 +8,21 @@
var domloader = {
queue: [],
+ after_queue: [],
+ version: 0,
progressbar: true,
total: 0,
icon: false,
id: 1,
debug: true,
- root : '',
+ root: '',
html: function (dom, path) {
domloader.id++;
domloader.log('Include::HTML::' + path);
domloader.queue.push(
function () {
- $.get(domloader.root + path, function (response) {
+ $.get(domloader.root + path, {v: domloader.version}, function (response) {
$(dom).replaceWith(response);
domloader.load(path);
}, 'text');
@@ -45,7 +47,7 @@ var domloader = {
domloader.log('Include::JS::' + path);
domloader.queue.push(
function () {
- $.get(domloader.root + path, function (response) {
+ $.get(domloader.root + path, {v: domloader.version}, function (response) {
domloader.id++;
$('body').append("\n");
domloader.load(path);
@@ -57,6 +59,15 @@ var domloader = {
load: function (src) {
$('body').css('overflow', 'hidden');
if (domloader.queue.length === 0) {
+
+ if (domloader.after_queue.length !== 0) {
+ var cb = null;
+ for (cb in domloader.after_queue) {
+ domloader.after_queue[cb]();
+ }
+ }
+
+
if (domloader.progressbar === false) {
$('#domloader_loading_show').fadeOut(100);
$('#domloader_loading_bg').fadeOut(100);
@@ -81,6 +92,11 @@ var domloader = {
}
},
+ onload: function (cb) {
+ domloader.log('Add::OnLoad ballback');
+ domloader.after_queue.push(cb);
+ },
+
init: function () {
window.onload = function () {
$('head').append('');