我正在尝试在我的反应应用程序中使用 signalR。当我像这样导入它时:
import { HubConnection } from '@aspnet/signalr-client';
没有uglify,构建运行良好。但是当我使用 uglify() 时,由于 uglify 和 es6 不兼容而失败。我找到了解决方法:
import { HubConnection } from '@aspnet/signalr-client/dist/browser/signalr-clientES5-1.0.0-alpha2-final.js';
但是现在当我尝试构建项目时,我遇到了这样的错误:
Cannot find module './HttpClient' from '...\node_modules\@aspnet\signalr-client\dist\browser'
这些模块位于
'...\node_modules\@aspnet\signalr-client\dist\src\...'
那么,在这种情况下如何修复构建?
构建任务本身:
gulp.task('build', () => {
return browserify({
entries: './wwwroot/js/client/app.jsx',
extensions: ['.jsx'],
debug: true
})
.transform('babelify', {
presets: ['es2015', 'react'],
plugins: ['transform-class-properties']
})
.bundle()
.on('error', function (err) {
gutil.log(gutil.colors.red.bold('[browserify error]'));
gutil.log(err.message);
this.emit('end');
})
.pipe(source('app.bundle.js'))
.pipe(streamify(uglify().on('error', function(e){
console.log(e);
})))
.pipe(sourcemaps.write('./maps'))
.pipe(gulp.dest('wwwroot/dist/client'));
});
提前致谢!