diff --git a/CHANGELOG.md b/CHANGELOG.md index b1797f3..9eacd7b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,11 +4,12 @@ All notable changes to this project will be documented in this file. The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/) and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html). -## [Unreleased] +## [1.0.6] ### Changed - License from GPLv3 to MIT ### Added +- new option `noCache` for fileObjects to prevent caching if needed for non-jsonp files - Changelog ## [1.0.5] - 2017-10-20 @@ -45,7 +46,8 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. ### Added - Initial Commit -[Unreleased]: /../compare/v1.0.5...HEAD +[Unreleased]: /../compare/v1.0.6...HEAD +[1.0.6]: /../compare/v1.0.5...v1.0.6 [1.0.5]: /../compare/v1.0.4...v1.0.5 [1.0.4]: /../compare/v1.0.3...v1.0.4 [1.0.3]: /../compare/v1.0.2...v1.0.3 diff --git a/README.md b/README.md index 9ee5f61..721e291 100644 --- a/README.md +++ b/README.md @@ -93,11 +93,14 @@ JS code as a string (! Because this could rely one some previous needed code loa **type**: `string` If omitted, stackLoad tries to guess it from a possible file extension. Otherwise assumes 'js' as default. Other possible values are: -- 'css' -- 'jsonp' +- `css` +- `jsonp` Using jsonp assumes the url already has the probably needed callback function name as part of the url. stackLoad just adds a timestamp to the url to make sure it is not cached - Anything else is considered javascript. +**noCache**: `boolean` +Set to true if you definately want to skip cache-load for the file and force redownloading from the server + #### stackObject Properties **files**: `string` | `array()` of strings | `fileObject` | `array()` of fileObjects The files will be synchronously loaded in the order of the array. So take care of possible dependencies. @@ -156,6 +159,14 @@ stackLoad({ }); ``` +Prevent Caching / Force Server reload (automatically enabled for jsonp files) +```javascript +stackLoad({ + url:'http://domain.tld/foo/bar.js', + noCache: true +}); +``` + Call a function when all files are loaded ```javascript stackLoad({ diff --git a/stackload.js b/stackload.js index 38289df..90ae380 100644 --- a/stackload.js +++ b/stackload.js @@ -109,7 +109,7 @@ o.type = guessed[1].toLowerCase(); } } - if(o.type.toLowerCase()==='jsonp') { + if(o.type.toLowerCase()==='jsonp' || o.noCache) { var dt= new Date().getTime(); if (o.url.match(/\?/)) { o.url += "&_="+dt; diff --git a/stackload.min.js b/stackload.min.js index fda9b6a..954d570 100644 --- a/stackload.min.js +++ b/stackload.min.js @@ -6,4 +6,4 @@ * @license GPLv3 https://gitlab.com/lubber/stackload/blob/master/LICENSE */ -!function(window,document){var registry=[],fullStack=[],currentLoadIndex=0,callBacks=[],stopAll=!1,continueStack=function(){++currentLoadIndex===callBacks[0].doneIndex&&(callBacks[0].success(),callBacks.shift()),currentLoadIndex===fullStack.length||stopAll||loadSingle()},stackLoadError=function(e){var t=e.target;console.error("[StackLoad Error] Missing file: "+(t.src?t.src:t.href)),!1===callBacks[0].error(e)&&(stopAll=!0),t.parentNode.removeChild(t),stackLoadDone(e)},stackLoadDone=function(e){var t,r=e.target;r.removeEventListener("error",stackLoadError),r.removeEventListener("load",stackLoadDone),r.jsonp&&r.parentNode&&r.parentNode.removeChild(r),stopAll?(t=callBacks[0].doneIndex-++currentLoadIndex)>0&&(fullStack.splice(currentLoadIndex,t),callBacks.shift(),callBacks.forEach(function(e,r,s){s[r].doneIndex-=t})):(r.href&&searchCssImport(document.styleSheets[document.styleSheets.length-1]),continueStack())},loadSingle=function(){var o=fullStack[currentLoadIndex],s;try{!o.check||""!==o.check&&!eval(o.check)?(o.type&&"css"===o.type?(s=document.createElement("link"),s.type="text/css",s.rel="stylesheet",s.href=o.url):(s=document.createElement("script"),s.type="text/javascript",s.src=o.url,s.async=!1,o.type&&"jsonp"===o.type&&(s.jsonp=!0)),document.head.appendChild(s),s.addEventListener("load",stackLoadDone),s.addEventListener("error",stackLoadError)):continueStack()}catch(e){console.error(e),continueStack()}},setup=function(e){if(void 0!==e&&("string"==typeof e||e.url?e={files:[e]}:Array.isArray(e)&&(e={files:e}),e.files)){var t=[];("string"==typeof e.files||e.files.url)&&(e.files=[e.files]),e.files.forEach(function(e){if("string"==typeof e&&(e={url:e}),e.url&&-1===registry.indexOf(e.url)){if(!e.type){var r=e.url.match(/\.([0-9a-zA-Z]+)(?:[?#]|$)/i);r&&(e.type=r[1].toLowerCase())}if("jsonp"===e.type.toLowerCase()){var s=(new Date).getTime();e.url.match(/\?/)?e.url+="&_="+s:e.url+="?_="+s}t.push(e),registry.push(e.url)}});var r=t.length;if("function"!=typeof e.success&&(e.success=function(){}),r>0){var s=(fullStack=fullStack.concat(t)).length;"function"!=typeof e.error&&(e.error=function(){}),callBacks.push({doneIndex:s,success:e.success,error:e.error}),currentLoadIndex===s-r&&loadSingle()}else e.success()}},searchCssImport=function(e){try{if(e.cssRules)for(var t=0,r=e.cssRules.length;t0&&(fullStack.splice(currentLoadIndex,r),callBacks.shift(),callBacks.forEach(function(e,t,s){s[t].doneIndex-=r})):(t.href&&searchCssImport(document.styleSheets[document.styleSheets.length-1]),continueStack())},loadSingle=function(){var o=fullStack[currentLoadIndex],s;try{!o.check||""!==o.check&&!eval(o.check)?(o.type&&"css"===o.type?(s=document.createElement("link"),s.type="text/css",s.rel="stylesheet",s.href=o.url):(s=document.createElement("script"),s.type="text/javascript",s.src=o.url,s.async=!1,o.type&&"jsonp"===o.type&&(s.jsonp=!0)),document.head.appendChild(s),s.addEventListener("load",stackLoadDone),s.addEventListener("error",stackLoadError)):continueStack()}catch(e){console.error(e),continueStack()}},setup=function(e){if(void 0!==e&&("string"==typeof e||e.url?e={files:[e]}:Array.isArray(e)&&(e={files:e}),e.files)){var r=[];("string"==typeof e.files||e.files.url)&&(e.files=[e.files]),e.files.forEach(function(e){if("string"==typeof e&&(e={url:e}),e.url&&-1===registry.indexOf(e.url)){if(!e.type){var t=e.url.match(/\.([0-9a-zA-Z]+)(?:[?#]|$)/i);t&&(e.type=t[1].toLowerCase())}if("jsonp"===e.type.toLowerCase()||e.noCache){var s=(new Date).getTime();e.url.match(/\?/)?e.url+="&_="+s:e.url+="?_="+s}r.push(e),registry.push(e.url)}});var t=r.length;if("function"!=typeof e.success&&(e.success=function(){}),t>0){var s=(fullStack=fullStack.concat(r)).length;"function"!=typeof e.error&&(e.error=function(){}),callBacks.push({doneIndex:s,success:e.success,error:e.error}),currentLoadIndex===s-t&&loadSingle()}else e.success()}},searchCssImport=function(e){try{if(e.cssRules)for(var r=0,t=e.cssRules.length;r