首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将文档注入systemjs-builder以捆绑angular 4.0.0应用程序?

如何将文档注入systemjs-builder以捆绑angular 4.0.0应用程序?
EN

Stack Overflow用户
提问于 2017-04-16 19:41:59
回答 1查看 348关注 0票数 18

我正在尝试捆绑一个angular 4.0.0应用程序。

我尝试过browserify,但是新的角度加载器插件(它允许在带有templateUrl的组件中不需要moduleId )没有被调用,因此模板以错误的路径结束。

所以我转到systemjs-builder,但问题是,当它运行这个插件时,它崩溃了,说文档没有定义。

有没有办法将文档注入构建器?

还是我做错了什么?

这是我正在测试的简单构建器( systemjs-config是angular quickstart )。

代码语言:javascript
复制
var path = require("path"); 
var Builder = require('systemjs-builder');

var builder = new Builder('src/frontend', 'src/frontend/systemjs.config.js');

builder .bundle('main.js', 'bundle.js') 
.then(function() {   
     console.log('Build complete'); 
}) 
.catch(function(err) {   
     console.log('Build error');   
     console.log(err); 
});
EN

回答 1

Stack Overflow用户

发布于 2017-06-21 05:01:36

我已经花了很长时间寻找这个问题的解决方案。由于我找不到它,我修改了systemjs-angular-loader.js以绕过该错误。有了这个技巧,systemjs-builder现在可以工作了。

代码语言:javascript
复制
var templateUrlRegex = /templateUrl\s*:(\s*['"`](.*?)['"`]\s*)/gm;
var stylesRegex = /styleUrls *:(\s*\[[^\]]*?\])/g;
var stringRegex = /(['`"])((?:[^\\]\\\1|.)*?)\1/g;

module.exports.translate = function(load){
  if (load.source.indexOf('moduleId') != -1) return load;

  var document=document || null;
  if(document){
    var url = document.createElement('a');
    url.href = load.address;

    var basePathParts = url.pathname.split('/');

    basePathParts.pop();
    var basePath = basePathParts.join('/');

    var baseHref = document.createElement('a');
    baseHref.href = this.baseURL;
    baseHref = baseHref.pathname;

    if (!baseHref.startsWith('/base/')) { // it is not karma
      basePath = basePath.replace(baseHref, '');
    }
  }
  else{
    var address=load.address;
    address=address.replace('file:///'+__dirname+'/', '');
    var basePathParts = address.split('/');

    basePathParts.pop();
    var basePath = basePathParts.join('/');
  }

  load.source = load.source
    .replace(templateUrlRegex, function(match, quote, url){
      var resolvedUrl = url;

      if (url.startsWith('.')) {
        resolvedUrl = basePath + url.substr(1);
      }

      return 'templateUrl: "' + resolvedUrl + '"';
    })
    .replace(stylesRegex, function(match, relativeUrls) {
      var urls = [];

      while ((match = stringRegex.exec(relativeUrls)) !== null) {
        if (match[2].startsWith('.')) {
          urls.push('"' + basePath + match[2].substr(1) + '"');
        } else {
          urls.push('"' + match[2] + '"');
        }
      }

      return "styleUrls: [" + urls.join(', ') + "]";
    });

  return load;
};

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43436850

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档