2016-11-19 12 views
0

У меня есть следующая конфигурация gulp.js. Это вроде работы. Как только я сохраню файл на сервере, я вижу, что возвращающиеся процессы начинаются и заканчиваются, как ожидалось. Однако Broswer recieves просто ошибка:RactJS hot reloading browserify/watchify/livereactload Ошибка websocket

bundle.js:37 WebSocket connection to 'wss://myPage:4474/' failed: Error in connection establishment: net::ERR_CONNECTION_TIMED_OUT 

Также есть видимое предупреждение:

Could not detect LiveReactLoad transform (livereactload/babel-transform). 

Однако столпотворение-преобразование, и я Установленные выполнила все шаги, необходимые инсталяция .. еще что-то есть неправильно, кто-нибудь знает что?

//gulpfile.js 
var source = { 
    html: 'react_src/index.html', 
    jsx: 'react_src/main.jsx' 
}; 

var dist = { 
    html: 'templates/project', 
    scripts: 'static/js' 
}; 

var sourcemaps = require('gulp-sourcemaps'); 
//Compile and Watch 
function compile() { 

    var bundler = watchify(browserify(
     { 
      entries: source.jsx, 
      debug: true, 
      extensions: ['.jsx'], 
      plugin: ["livereactload"], 

     }).transform(babel, {presets: ['es2015','stage-0', 'react']})); 

    function rebundle() { 
     return bundler.bundle() 
     // log errors if they happen 
     .on('error', function(err) {console.error(err); this.emit('end'); }) 
     .pipe(vinyl_source('bundle.js')) 
     // optional, remove if you don't need to buffer file contents 
     .pipe(buffer()) 
     // optional, remove if you dont want sourcemaps 
     .pipe(sourcemaps.init({loadMaps: true})) // loads map from browserify file 
      // Add transformation tasks to the pipeline here. 
     .pipe(sourcemaps.write('./')) // writes .map file 
     .pipe(gulp.dest(dist.scripts)); 
    } 

    if (watch) { 
     // watch html 

    // processing method 
    let _build =() => { 
    return bundler.bundle() 
     .on('error', (err) => { 
     gutil.log(err.stack); 
     }) 
     .pipe(vinyl_source('bundle.js')) 
     .pipe(gulp.dest('build')); 
    }; 

    // on change 
    bundler.on('update',() => { 
     gutil.log('Rerunning browserify...'); 
     const updateStart = Date.now(); 
     _build().on('end',() => { 
     gutil.log(`...Done ${Date.now() - updateStart} ms`);   
     }); 
    }); 

    } 

    rebundle(); 
} 


function watch() { 
    return compile(true); 
} 
//gulp.task('js', function (cb) { bundle().on('end', cb); }); 

// build jsx 
gulp.task('build', function() { 
    return compile(); 
}); 

gulp.task('watch', function() { 
    return watch(); 
}); 


// build html 
gulp.task('replaceHTML', function() { 
    gulp.src(source.html) 
     .pipe(htmlReplace({ 
      'js': '<script src="{% static \'js\\bundle.js\' %}"></script>' 
     })) 
     .pipe(gulp.dest(dist.html)); 
}); 

gulp.task('server', ['replaceHTML'], function() { 
    return gulp.src(source.jsx) 
    .pipe(livereactload({ 
    host: '0.0.0.0', 
    port: 8081 
    })); 
}); 

ответ

0

Вы должны пройти plugins вариант для babel, внутри вызова transform функции:

.transform(babel, { presets: ['es2015','stage-0', 'react'], plugins: [...] }));

 Смежные вопросы

  • Нет связанных вопросов^_^