javascript - react 服務端渲染怎麼處理less文件
黄舟
黄舟 2017-06-05 11:11:36
0
1
1195

背景:用react.js node 實作react元件服務端渲染。

由於目前node 還不支援import,我用nodemon --harmony server.js --exec babel-node指令執行,其中server.js是後端入口文件,這樣可以支援import了,但是當我使用antd 的Button 元件時卻報不支援@import, 因為antd 的button 元件導入了default.less,怎麼才能解決這個問題呢?

server.js

#
import React, { Component } from 'react';
import { renderToString } from 'react-dom/server'
import { Button } from 'antd';

var Koa = require('koa');
var app = new Koa();
const render = require('koa-ejs');
const path = require('path');

render(app, {
  root: path.join(__dirname, 'server/view'),
  layout: 'template',
  viewExt: 'html',
  cache: false,
  debug: true
});

app.use(async function (ctx, next){
  const html = renderToString(
    <Button>hello</Button>
  );
  await ctx.render('demo', {'html': html});
});

app.keys = ['i love yuewen'];

app.listen(3000);

報錯如下:

#
/Users/joy.hu/Sites/yue/node_modules/antd/lib/style/index.less:1
(function (exports, require, module, __filename, __dirname) { @import "./themes/default";
                                                              ^
SyntaxError: Invalid or unexpected token
    at createScript (vm.js:53:10)
    at Object.runInThisContext (vm.js:95:10)
    at Module._compile (module.js:543:28)
    at Module._extensions..js (module.js:580:10)
    at Object.require.extensions.(anonymous function) [as .js] (/Users/joy.hu/Sites/yue/node_modules/babel-register/lib/node.js:152:7)
    at Module.load (module.js:488:32)
    at tryModuleLoad (module.js:447:12)
    at Function.Module._load (module.js:439:3)
    at require (internal/module.js:20:19)
    at Object.<anonymous> (/Users/joy.hu/Sites/yue/node_modules/antd/lib/button/style/index.js:3:1)
[nodemon] app crashed - waiting for file changes before starting...
黄舟
黄舟

人生最曼妙的风景,竟是内心的淡定与从容!

全部回覆(1)
世界只因有你

https://babeljs.io/docs/usage...

https://github.com/babel/exam...

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板