电子 - Javascript(ES6) - 导入远程类

时间:2015-09-01 13:54:42

标签: javascript ecmascript-6 electron

编辑:
02/09 -
似乎导入代码很好(就像响应中的那个),但是我的类代码不好(坏的ES6?糟糕的转换?)

首发帖子:
我正在尝试从我的电子应用程序中导入一个远程类。

  • 我有一个静态服务器来托管我的html / js文件
  • 我想从该服务器导入一个类,以便在我的电子应用程序的主过程中使用它。

有可能吗?

我找到了一些解决方案:

var vm = require('vm')
var concat = require('concat-stream');
require('http')
  .get(
    {
      host: 'localhost', 
      port: 8123, 
      path:"/dist/SomeViewModel.js" 
    }, 
    function(res) {
      res.setEncoding('utf8');
      res.pipe(concat({ encoding: 'string' }, function(remoteSrc) {
        vm.runInThisContext(remoteSrc, 'remote_modules/SomeViewModel.js')
      }));
    } );

它似乎没有错误,但我不明白如何使用它... 例如var someVM = new SomeViewModel()不起作用(并不感到惊讶......)。

这是SomeViewModel:

export default class SomeViewModel {
  constructor(options) {
    this.element1 = options.element1,
    this.element2 = options.element2
  };
}

这个班级是巴贝尔化的,并成为:

(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
"use strict";

Object.defineProperty(exports, "__esModule", {
  value: true
});

function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }

var SomeViewModel = function SomeViewModel(options) {
  _classCallCheck(this, SomeViewModel);

  this.element1 = options.element1, this.element2 = options.element2;
};

exports["default"] = SomeViewModel;
module.exports = exports["default"];

},{}]},{},[1]);

//# sourceMappingURL=SomeViewModel.js.map

这是一个好方法吗? (我知道安全性,它只是如何)

1 个答案:

答案 0 :(得分:1)

在这种情况下,我会下载文件并将其存储在磁盘上,一旦完成,就需要该文件。

var http = require('http'),
    fs = require('fs');

var file = fs.createWriteStream('./tmp/SomeViewModel.js');
http.get({
    // your options
}, function (res) {
    // set encoding, etc.
    res.pipe(file);
    file.on('finish', function() {
        file.close(function() {
            // do stuff
            // var SomeViewModel = require('./tmp/SomeViewModel.js');
        });
    });
});