zoukankan      html  css  js  c++  java
  • dev-server.js

    var path = require('path')
    var express = require('express')
    var webpack = require('webpack')
    var config = require('../config')
    var proxyMiddleware = require('http-proxy-middleware')
    var webpackConfig = process.env.NODE_ENV === 'testing'
    	? require('./webpack.prod.conf')
    	: require('./webpack.dev.conf')
    
    // default port where dev server listens for incoming traffic
    var port = process.env.PORT || config.dev.port
    // Define HTTP proxies to your custom API backend
    // https://github.com/chimurai/http-proxy-middleware
    var proxyTable = config.dev.proxyTable
    
    var app = express()
    
    var appData = require('../data.json');
    var seller = appData.seller;
    var goods = appData.goods;
    var ratings = appData.ratings;
    
    var apiRoutes = express.Router();
    
    apiRoutes.get('/seller', function (req, res) {
    	res.json({
    		errno: 0,
    		data: seller
    	});
    });
    
    apiRoutes.get('/goods', function (req, res) {
    	res.json({
    		errno: 0,
    		data: goods
    	});
    });
    
    apiRoutes.get('/ratings', function (req, res) {
    	res.json({
    		errno: 0,
    		data: ratings
    	});
    });
    
    app.use('/api', apiRoutes)
    
    var compiler = webpack(webpackConfig)
    
    var devMiddleware = require('webpack-dev-middleware')(compiler, {
    	publicPath: webpackConfig.output.publicPath,
    	stats: {
    		colors: true,
    		chunks: false
    	}
    })
    
    var hotMiddleware = require('webpack-hot-middleware')(compiler)
    // force page reload when html-webpack-plugin template changes
    compiler.plugin('compilation', function (compilation) {
    	compilation.plugin('html-webpack-plugin-after-emit', function (data, cb) {
    		hotMiddleware.publish({action: 'reload'})
    		cb()
    	})
    })
    
    // proxy api requests
    Object.keys(proxyTable).forEach(function (context) {
    	var options = proxyTable[context]
    	if (typeof options === 'string') {
    		options = {target: options}
    	}
    	app.use(proxyMiddleware(context, options))
    })
    
    // handle fallback for HTML5 history API
    app.use(require('connect-history-api-fallback')())
    
    // serve webpack bundle output
    app.use(devMiddleware)
    
    // enable hot-reload and state-preserving
    // compilation error display
    app.use(hotMiddleware)
    
    // serve pure static assets
    var staticPath = path.posix.join(config.dev.assetsPublicPath, config.dev.assetsSubDirectory)
    app.use(staticPath, express.static('./static'))
    
    module.exports = app.listen(port, function (err) {
    	if (err) {
    		console.log(err)
    		return
    	}
    	console.log('Listening at http://localhost:' + port + '
    ')
    })
    
    You can change the world with your heart,even a lot of changes sometimes unless you won't geiv up....
  • 相关阅读:
    堆排序
    如何在.Net中使用MongoDB
    二叉树遍历 C#
    对C# 中Readonly的再认识
    对C# 构造函数的理解
    TypeScript学习: 九、TypeScript的泛型
    TypeScript学习: 八、TypeScript的属性接口用法封装ajax
    锚点跳转不改变History
    设计模式笔记—代理模式
    小程序开发二:上手第一个小程序
  • 原文地址:https://www.cnblogs.com/xiongwei2017/p/6654347.html
Copyright © 2011-2022 走看看