Как настроить preact SSR проект, используя rollupjs, чтобы избежать preact $ 1? - PullRequest
0 голосов
/ 06 февраля 2019

Я использую rollupjs для упаковки проекта SSR с помощью preact.Я использую @ babel-plugin-transform-Reaction-jsx для преобразования jsx.Я конфиг преакт в глобальном.Но в комплекте есть преакт $ 1 вместо преакта.Похоже, что он конфликтует с прагмой: preact.h.Я не хочу, чтобы появился preact $ 1.Как настроить?

rollup.config.js

import babel from 'rollup-plugin-babel';
import resolve from 'rollup-plugin-node-resolve';
import commonjs from 'rollup-plugin-commonjs';

const dirs = {
    src: './src/demo',
    dist: './dist'
}

export default [
    {
        external: ['preact', 'preact-render-to-string'],
        
        input: `${dirs.src}/server.js`,
        output: {
            file: `${dirs.dist}/server.js`,
            format: 'iife',
            globals: {
                'preact': 'require("preact")',
                'preact-render-to-string': 'require("preact-render-to-string")'
            }
        },
       
        plugins: [
            resolve({
                jsnext: true,
                main: true,
                browser: true
            }),
            
            
            babel({
                exclude: 'node_modules/**',
                presets: [
                    [
                        '@babel/preset-env', {
                            targets: {
                                node: 'current'
                            }
                        }
                    ]
                ],
                plugins: [
                    [
                        '@babel/transform-react-jsx', { 'pragma': 'preact.h'}
                    ]
                ]
            }),
            commonjs({
                include: 'node_modules/**'            
            })
            
        ]
    }
    
]

app.jsx

import {Component} from 'preact';
import Foo from './foo.jsx';
class App extends Component {
    render(props, state) {
        let {text} = state;
        return (
            <div>
                <Foo/>
                <div>{text}</div>
            </div>
        )
    }
}
export default App;

server.js

import {h} from 'preact';
import preactRenderToString from 'preact-render-to-string';
import App from './app.jsx';

let html = preactRenderToString(
    <App />
)

console.log(html);

bundlejs -> server.js

(function (preact$1, preactRenderToString) {
    'use strict';

    preactRenderToString = preactRenderToString && preactRenderToString.hasOwnProperty('default') ? preactRenderToString['default'] : preactRenderToString;

    class Foo extends preact$1.Component {
      render(props, state) {
        let {
          text
        } = state;
        return preact.h("span", null, text);
      }

    }

    class App extends preact$1.Component {
      render(props, state) {
        let {
          text
        } = state;
        return preact.h("div", null, preact.h(Foo, null), preact.h("div", null, text));
      }

    }

    let html = preactRenderToString(preact.h(App, null));
    console.log(html);

}(require("preact"), require("preact-render-to-string")));
...