SystemJS和SignalR

时间:2016-06-10 15:13:20

标签: signalr systemjs jspm

有没有人让SystemJS和SignalR一起工作? 我一直在尝试使用SystemJS(来自jspm)来加载SignalR,但无论我做什么,总是存在异步加载器的竞争条件。它加载的次数约为一半,在初始化代码运行时,SignalR不会加载。

System.config({
    baseURL: '/Scripts',
    map: {
        'jquery': '/bundles/jquery',
        'jquery.ui.widget': 'jquery-ui-1.10.4.js',
    },
    meta: {
        '/signalr/hubs': {
            deps: ['jquery.signalR-2.2.0.min.js']
        }
    }
});
Promise.all([
    System.import('jQuery.FileUpload/jquery.fileupload.js'),
    System.import('knockout-3.1.0.debug.js'),
    System.import('/signalr/hubs')
])
.then(function (libs, gg) {
    var ko = libs[1];

    //My init code
    var chat = $.connection.jobProgress;
    // Throws '$.connection is undefined' about half the time
})

2 个答案:

答案 0 :(得分:2)

使用signalr package config尝试此操作。

System.config({
    baseURL: 'Scripts',
    map: {
            "signalr-jquery": "Scripts/jquery.signalR-2.2.0",
            "signalr": "signalr",
            "jquery": "/bundles/jquery" //I would pull it from jspm also
        },
        meta: {
            "jquery": {
                "format": "cjs"

            },
            "signalr-jquery": {
                "format": "global",
                "deps": ["jquery"]
            }
        },
        packages: {
            "signalr": {
                "format": "global",
                "defaultExtension": false,
                "meta": {
                    "hubs": {
                        "format": "global",
                        "deps": ["signalr-jquery"]
                    }
                }
            }
        }
})

并导入集线器

    System.import('signalr/hubs').then(function(hubs) {

   })

答案 1 :(得分:0)

我可以使用此配置加载它:

System.config({
    map: {
      'jquery': 'node_modules/jquery/dist/jquery.js',
      'signalrJquery': 'jquery.signalR-2.2.0.js',
      'signalrHubs': 'jquery.signalR-2.2.0.Hubs.js'
    },
    meta: {
        "jquery-1.10.2.js": { exports: "$" }, 
        signalrJquery: {exports: "$"},
        signalrHubs: {
            deps: ['jquery-1.10.2.js', 'signalrJquery'],
        exports: "$"
    }
});

然后像这样获取它:

import * as $ from 'signalrHubs';

var $ = require('signalrHubs');

请注意,依赖项中的jquery版本是signalr所依赖的版本。如果需要,网站的其余部分可以使用更新的版本。