だから私はWebワーカーを作成しています:
var arrayit = function(obj) {
return Array.prototype.slice.call(obj);
};
work = arrayit(images);
console.log(work);
//work = images.push.apply( images, array );
// Method : "load+scroll"
var worker = new Worker('jail_worker.js');
worker.postMessage(work)
worker.onmessage = function(event) {
console.log("Worker said:" + event.data);
};
画像は次のとおりです。
$.jail.initialStack = this;
// Store the selector into 'triggerEl' data for the images selected
this.data('triggerEl', (options.selector) ? $(options.selector) : $window);
var images = this;
私の問題はこれと関係があると思います:
http://dev.w3.org/html5/spec/Overview.html#safe-passing-of-structured-data
どうすればこれを回避できますか?ご覧のとおり、ホストオブジェクトを実際の配列にスライスしようとしましたが、うまくいきませんでした。
これが私がハッキングしているファイルへのリンクです:
https://github.com/jtmkrueger/JAIL
アップデート - - - - - - - - - - - - - - - - - - - - - - - - - -
これは、@davinから受け入れられた回答に基づいて私がしなければならなかったことです。
var arrayit = function(obj) {
return Array.prototype.slice.call(obj);
};
imgArray = arrayit(images);
work = _.map(images, function(i){ return i.attributes[0].ownerElement.outerHTML; });
var worker = new Worker('jail_worker.js');
worker.postMessage(work)
worker.onmessage = function(event) {
console.log("Worker said:" + event.data);
};
注:互換性を確保するためにunderscore.jsを使用しました。