guybedford / amd-loader Goto Github PK
View Code? Open in Web Editor NEWRequireJS loader plugin helper for transpiler and template plugins
License: MIT License
RequireJS loader plugin helper for transpiler and template plugins
License: MIT License
Please register your package on http://bower.herokuapp.com/packages/. By default bower will install package from git://github.com/ajaxorg/node-amd-loader.git
RequireJS can be run inside a Web Worker. I'm using the CJS plugin to use CommonJS modules inside a web worker, but I'm getting the "Environment unsupported" error message from amd-loader
.
Web Workers do support XMLHttpRequest
, so enabling amd-loader
to run inside workers should be a matter of extending this if
condition to check for availability of Web Worker APIs in addition to checking the availability of the window
object.
Because this is probably a trivial change and there are many ways to implement this, I'm not opening a pull-request. To save time, here are the changes that seem to work reliably (in file amd-loader.js
near line 80):
+ // from require.js source
+ var isBrowser = !!(typeof window !== 'undefined' && typeof navigator !== 'undefined' && window.document);
+ var isWebWorker = !isBrowser && typeof importScripts !== 'undefined';
+
- if (typeof window != 'undefined') {
+ if (isBrowser || isWebWorker) {
var progIds = ['Msxml2.XMLHTTP', 'Microsoft.XMLHTTP', 'Msxml2.XMLHTTP.4.0'];
var getXhr = function(path) {
// check if same domain
var sameDomain = true,
domainCheck = /^(\w+:)?\/\/([^\/]+)/.exec(path);
- if (typeof window != 'undefined' && domainCheck) {
+ if (domainCheck) {
- sameDomain = domainCheck[2] === window.location.host;
+ sameDomain = domainCheck[2] === location.host;
if (domainCheck[1])
- sameDomain &= domainCheck[1] === window.location.protocol;
+ sameDomain &= domainCheck[1] === location.protocol;
}
Note that window
is not defined in a web worker, and so the global object in a web worker can be accessed using self
but not window
. self
can also be used to access the global object in the main browser "thread". However, because self
is commonly declared as a variable by many users, I don't think it can be used reliably. Getting access to the global object reliably is not very trivial or elegant, so short of using several typeof
checks, I think it is best to use location.host
and location.protocol
directly instead of window.location.host
and window.location.protocol
respectively. A more robust solution would be great.
Another solution, as shown in a Stack Overflow answer, could be to ask users of this library to define the window
object to be the global scope before executing amd-loader
inside a web worker:
// configure paths and then import requirejs
importScripts('path/to/requirejs/require.js');
var window = self; // returns a reference to the WorkerGlobalScope
// code using amd-loader or plugins based on it
require(['cjs!some-module'], function (someModule) {
// ...
});
Hi @guybedford !
Thanks for this sweat library, I'm currently using with Ractive.js and I try to run them in node.js
I just got an issue when obj window is declared inside a node application, so I decide to fork it and try to do a dirty fix. Do you think could be useful for the library? Do you need a pul request?
RequireJS can be run inside a Web Worker. I'm using the CJS plugin to use CommonJS modules inside a web worker, but I'm getting the "Environment unsupported" error message from amd-loader
.
Web Workers do support XMLHttpRequest
, so enabling amd-loader
to run inside workers should be a matter of extending this if
condition to check for availability of Web Worker APIs in addition to checking the availability of the window
object.
Because this is probably a trivial change and there are many ways to implement this, I'm not opening a pull-request. To save time, here are the changes that seem to work reliably (in file amd-loader.js
near line 80):
+ // from require.js source
+ var isBrowser = !!(typeof window !== 'undefined' && typeof navigator !== 'undefined' && window.document);
+ var isWebWorker = !isBrowser && typeof importScripts !== 'undefined';
+
- if (typeof window != 'undefined') {
+ if (isBrowser || isWebWorker) {
var progIds = ['Msxml2.XMLHTTP', 'Microsoft.XMLHTTP', 'Msxml2.XMLHTTP.4.0'];
var getXhr = function(path) {
// check if same domain
var sameDomain = true,
domainCheck = /^(\w+:)?\/\/([^\/]+)/.exec(path);
- if (typeof window != 'undefined' && domainCheck) {
+ if (domainCheck) {
- sameDomain = domainCheck[2] === window.location.host;
+ sameDomain = domainCheck[2] === location.host;
if (domainCheck[1])
- sameDomain &= domainCheck[1] === window.location.protocol;
+ sameDomain &= domainCheck[1] === location.protocol;
}
Note that window
is not defined in a web worker, and so the global object in a web worker can be accessed using self
but not window
. self
can also be used to access the global object in the main browser "thread". However, because self
is commonly declared as a variable by many users, I don't think it can be used reliably. Getting access to the global object reliably is not very trivial or elegant, so short of using several typeof
checks, I think it is best to use location.host
and location.protocol
directly instead of window.location.host
and window.location.protocol
respectively. A more robust solution would be great.
Another solution, as shown in a Stack Overflow answer, could be to ask users of this library to define the window
object to be the global scope before executing amd-loader
inside a web worker:
// configure paths and then import requirejs
importScripts('path/to/requirejs/require.js');
var window = self; // returns a reference to the WorkerGlobalScope
// code using amd-loader or plugins based on it
require(['cjs!some-module'], function (someModule) {
// ...
});
I am loving the idea of this project. Often times in building Require.js plugins the need to run something different for the build to say, generate strings... Where as in the browser to export interfaces. I am having trouble seeing where the build specific implementation should exist, take for example Handlebars...
callback(Handlebars.compile(template));
// Potentially do lots of other mutation here...
callback(Handlebars.precompile(template));
Using amd-loader how would one provide build specific and runtime specific functionality?
A declarative, efficient, and flexible JavaScript library for building user interfaces.
๐ Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
An Open Source Machine Learning Framework for Everyone
The Web framework for perfectionists with deadlines.
A PHP framework for web artisans
Bring data to life with SVG, Canvas and HTML. ๐๐๐
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
Some thing interesting about web. New door for the world.
A server is a program made to process requests and deliver data to clients.
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
Some thing interesting about visualization, use data art
Some thing interesting about game, make everyone happy.
We are working to build community through open source technology. NB: members must have two-factor auth.
Open source projects and samples from Microsoft.
Google โค๏ธ Open Source for everyone.
Alibaba Open Source for everyone
Data-Driven Documents codes.
China tencent open source team.