Sapper/Svelte rollup/plugin-json 条纹 js 出错
Sapper/Svelte rollup/plugin-json giving error with stripejs
我正在使用 sapper 和 stripejs。使用命令 "npm install stripe --save" 安装 stripejs 并按照 npm 指令使用包后:
import Stripe from 'stripe';
const stripe = new Stripe('mystripekey');
我在重新加载时遇到错误。这是一个截图,因为我以前从未见过它,我根本不知道如何解决这个问题。它需要来自 rollup team/expert 的人并让我们知道如何修复它:
我按照说明安装了插件-json,它显示在 rollup.config.js 中,所以它不是条带包,但似乎汇总有错误或未处理某物。
这是我的 rollup.config.js 从 this url 安装汇总插件后:
import resolve from '@rollup/plugin-node-resolve';
import replace from '@rollup/plugin-replace';
import commonjs from '@rollup/plugin-commonjs';
import svelte from 'rollup-plugin-svelte';
import babel from 'rollup-plugin-babel';
import { terser } from 'rollup-plugin-terser';
import config from 'sapper/config/rollup.js';
import pkg from './package.json';
import json from '@rollup/plugin-json';
const mode = process.env.NODE_ENV;
const dev = mode === 'development';
const legacy = !!process.env.SAPPER_LEGACY_BUILD;
const onwarn = (warning, onwarn) => (warning.code === 'CIRCULAR_DEPENDENCY' && /[/\]@sapper[/\]/.test(warning.message)) || onwarn(warning);
const dedupe = importee => importee === 'svelte' || importee.startsWith('svelte/');
export default {
client: {
input: config.client.input(),
output: config.client.output(),
plugins: [
json(),
replace({
'process.browser': true,
'process.env.NODE_ENV': JSON.stringify(mode)
}),
svelte({
dev,
hydratable: true,
emitCss: true
}),
resolve({
browser: true,
dedupe
}),
commonjs(),
legacy && babel({
extensions: ['.js', '.mjs', '.html', '.svelte'],
runtimeHelpers: true,
exclude: ['node_modules/@babel/**'],
presets: [
['@babel/preset-env', {
targets: '> 0.25%, not dead'
}]
],
plugins: [
'@babel/plugin-syntax-dynamic-import',
['@babel/plugin-transform-runtime', {
useESModules: true
}]
]
}),
!dev && terser({
module: true
})
],
onwarn,
},
server: {
input: config.server.input(),
output: config.server.output(),
plugins: [
replace({
'process.browser': false,
'process.env.NODE_ENV': JSON.stringify(mode)
}),
svelte({
generate: 'ssr',
dev
}),
resolve({
dedupe
}),
commonjs()
],
external: Object.keys(pkg.dependencies).concat(
require('module').builtinModules || Object.keys(process.binding('natives'))
),
onwarn,
},
serviceworker: {
input: config.serviceworker.input(),
output: config.serviceworker.output(),
plugins: [
resolve(),
replace({
'process.browser': true,
'process.env.NODE_ENV': JSON.stringify(mode)
}),
commonjs(),
!dev && terser()
],
onwarn,
}
};
来自软件包安装说明:
我想这样做:
**Then call rollup either via the CLI or the API.
With an accompanying file src/index.js, the local package.json file would
now be importable as seen below:**
// src/index.js
import pkg from './package.json';
console.log(`running version ${pkg.version}`);
但是我没有 index.js 文件?...这是我的项目 sapper 结构:
没有最后一步,它似乎破坏了整个事情,因为当我重新加载所有内容时,我在命令提示符中得到了这个:
用 localhost:3000/stripe 打开浏览器给我一个 500 错误
Failed to resolve module specifier "http". Relative references must start with either "/", "./", or "../".
TypeError: Failed to resolve module specifier "http". Relative references must start with either "/", "./", or "../".
我该如何处理这个问题?感谢任何帮助,我认为这是汇总配置问题。
您必须安装 plugin-json
并在 rollup
配置中正确使用它,在 plugins
中
安装后确保你的 package.json
中有它
...
"@rollup/plugin-json": "^4.0.0",
然后在里面 rollup.config.js
:
import json from '@rollup/plugin-json';
...
export default {
input: 'src/main.js',
output: {
...
},
plugins: [
json(), <<--------- HERE
svelte({
...
现在应该可以了。
对于我的情况,在 rollup.config.js 中安装 @rollup/plugin-json 和配置后问题仍然存在。
我发现 rollup 配置有两个部分:客户端和服务器,将 json() 配置添加到两个部分的插件后问题就消失了。
希望能帮到一些人。
我正在使用 sapper 和 stripejs。使用命令 "npm install stripe --save" 安装 stripejs 并按照 npm 指令使用包后:
import Stripe from 'stripe';
const stripe = new Stripe('mystripekey');
我在重新加载时遇到错误。这是一个截图,因为我以前从未见过它,我根本不知道如何解决这个问题。它需要来自 rollup team/expert 的人并让我们知道如何修复它:
我按照说明安装了插件-json,它显示在 rollup.config.js 中,所以它不是条带包,但似乎汇总有错误或未处理某物。
这是我的 rollup.config.js 从 this url 安装汇总插件后:
import resolve from '@rollup/plugin-node-resolve';
import replace from '@rollup/plugin-replace';
import commonjs from '@rollup/plugin-commonjs';
import svelte from 'rollup-plugin-svelte';
import babel from 'rollup-plugin-babel';
import { terser } from 'rollup-plugin-terser';
import config from 'sapper/config/rollup.js';
import pkg from './package.json';
import json from '@rollup/plugin-json';
const mode = process.env.NODE_ENV;
const dev = mode === 'development';
const legacy = !!process.env.SAPPER_LEGACY_BUILD;
const onwarn = (warning, onwarn) => (warning.code === 'CIRCULAR_DEPENDENCY' && /[/\]@sapper[/\]/.test(warning.message)) || onwarn(warning);
const dedupe = importee => importee === 'svelte' || importee.startsWith('svelte/');
export default {
client: {
input: config.client.input(),
output: config.client.output(),
plugins: [
json(),
replace({
'process.browser': true,
'process.env.NODE_ENV': JSON.stringify(mode)
}),
svelte({
dev,
hydratable: true,
emitCss: true
}),
resolve({
browser: true,
dedupe
}),
commonjs(),
legacy && babel({
extensions: ['.js', '.mjs', '.html', '.svelte'],
runtimeHelpers: true,
exclude: ['node_modules/@babel/**'],
presets: [
['@babel/preset-env', {
targets: '> 0.25%, not dead'
}]
],
plugins: [
'@babel/plugin-syntax-dynamic-import',
['@babel/plugin-transform-runtime', {
useESModules: true
}]
]
}),
!dev && terser({
module: true
})
],
onwarn,
},
server: {
input: config.server.input(),
output: config.server.output(),
plugins: [
replace({
'process.browser': false,
'process.env.NODE_ENV': JSON.stringify(mode)
}),
svelte({
generate: 'ssr',
dev
}),
resolve({
dedupe
}),
commonjs()
],
external: Object.keys(pkg.dependencies).concat(
require('module').builtinModules || Object.keys(process.binding('natives'))
),
onwarn,
},
serviceworker: {
input: config.serviceworker.input(),
output: config.serviceworker.output(),
plugins: [
resolve(),
replace({
'process.browser': true,
'process.env.NODE_ENV': JSON.stringify(mode)
}),
commonjs(),
!dev && terser()
],
onwarn,
}
};
来自软件包安装说明: 我想这样做:
**Then call rollup either via the CLI or the API.
With an accompanying file src/index.js, the local package.json file would
now be importable as seen below:**
// src/index.js
import pkg from './package.json';
console.log(`running version ${pkg.version}`);
但是我没有 index.js 文件?...这是我的项目 sapper 结构:
没有最后一步,它似乎破坏了整个事情,因为当我重新加载所有内容时,我在命令提示符中得到了这个:
用 localhost:3000/stripe 打开浏览器给我一个 500 错误
Failed to resolve module specifier "http". Relative references must start with either "/", "./", or "../".
TypeError: Failed to resolve module specifier "http". Relative references must start with either "/", "./", or "../".
我该如何处理这个问题?感谢任何帮助,我认为这是汇总配置问题。
您必须安装 plugin-json
并在 rollup
配置中正确使用它,在 plugins
安装后确保你的 package.json
...
"@rollup/plugin-json": "^4.0.0",
然后在里面 rollup.config.js
:
import json from '@rollup/plugin-json';
...
export default {
input: 'src/main.js',
output: {
...
},
plugins: [
json(), <<--------- HERE
svelte({
...
现在应该可以了。
对于我的情况,在 rollup.config.js 中安装 @rollup/plugin-json 和配置后问题仍然存在。
我发现 rollup 配置有两个部分:客户端和服务器,将 json() 配置添加到两个部分的插件后问题就消失了。
希望能帮到一些人。