bowl is a loader that caches scripts and stylesheets with localStorage. After receiving any scripts or stylesheets, this tiny JavaScript library will save them to the browser's localStorage. When the file is requested next time, bowl will read it from localStorage and inject it to the webpage.
$ npm install bowl.js
then insert an script
tag to your page(head
tag is recommended):
<script src="node_modules/bowl.js/lib/bowl.js"></script>
For those scripts that need to be cached, you do not have to insert script
tags to the pages. Just write a little piece of JavaScript and bowl will take care of it.
<script>
var bowl = new Bowl()
bowl.add([
{ url: 'dist/vendor.[hash].js', key: 'vendor' },
{ url: 'dist/app.[hash].js', key: 'app' }
])
bowl.inject()
</script>
bowl will add these scripts to cache(currently localStorage). whenever the hashes in the filenames get modified, bowl will update the files in the cache. For more useful functions of bowl, just checkout the API document.
After cloning the repo, run:
$ yarn install # yep, yarn is recommended. :)
# watch and auto rebuild lib/bowl.js and lib/bowl.min.js
$ npm run dev
# watch and auto re-run unit tests in Chrome
$ npm run test:unit
# build all dist files
$ npm run build
build
: contains build-related configuration files.lib
: contains build files for distribution, after runningtest
script, files in this directory will be updated as well.test
: contains all tests. The unit tests are written with Jasmine and run with Karma.src
: contains the source code. Obviously, The codebase is written in ES2015.
bowl will add a property named bowl
to the global object, which is window
in browsers. Bowl has several methods for you.
bowl.configure(config)
config: an object contains custom settings of bowl instance, supported settings are:
- timeout: time limit of fetching resources(in milliseconds).
Examples
bowl.configure({
timeout: 10000
})
bowl.add(scripts)
scripts: an array of objects with the following fields:
- url(required): the URI of the script to be handled. Because of the CORS restrictions, the URI should be on the same origin as the caller. You can Either use an absolute address or just use path. bowl converts all of them to absolute addresses.
- key: the name for bowl to identify the script, if you don't specify this field, it defaults to the url.
- noCache: defaults to false. Bowl won't cache the resource if it's true.
Examples
bowl.add([
{ url: '/main.js', key: 'main' }
])
bowl.inject()
this method triggers the handling of the scripts added by bowl.add()
method. Bowl will check if the script has been stored in the localStorage. If not, bowl will fetch it from the server and save it to cache(localStorage).
bowl.remove(scripts)
scripts: this parameter supports two types:
String: indicates the key of the ingredient to be removed.
Object: an object with the following fields:
- url: url of the script you want to remove from the controlling scope of bowl.
- key: id of the script to be removed.
bowl.remove()
Parameter scripts
is optional. When scripts
is not not Provided, bowl will remove all the ingredients from bowl instance and local storage.
MIT