Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

使用next.js并按照文档使用部分引入,则会报错Syntax error: Unexpected token > 1 | import type { AppProps } from 'next/app' #267

Open
1 task
Neojoke opened this issue May 20, 2024 · 1 comment

Comments

@Neojoke
Copy link

Neojoke commented May 20, 2024

Basic Info

  • Package Name And Version: @arco-design/[email protected]
  • Phone Model And Version: 17621703478

Steps to reproduce

设置 �.babelrc.js:module.exports = function (api) {
api.cache(true);

const presets =  ["next/babel", "@babel/preset-typescript"];
const plugins = [
    ["import", {
        "libraryName": "@arco-design/mobile-react/esm/icon", // 注意如果是 SSR 环境,这里需将 `esm` 替换为 `cjs`
        "libraryDirectory": "",
        "camel2DashComponentName": false,
    }]
];
return {
  presets,
  plugins
};

}
tsconfig.json:
{
"compilerOptions": {
"target": "es5",
"lib": ["dom", "dom.iterable", "esnext"],
"allowJs": true,
"strict": false,
"skipLibCheck": true,
"forceConsistentCasingInFileNames": true,
"noEmit": true,
"esModuleInterop": true,
"module": "esnext",
"moduleResolution": "node",
"resolveJsonModule": true,
"isolatedModules": true,
"jsx": "preserve",
"incremental": true,
"baseUrl": "./src",
"paths": {
"@/": ["./"]
},
"rootDirs": ["common/src/", "arco-design-pro-cra/src/", "arco-design-pro-next/src/"]
},
"include": ["/*.ts", "/*.tsx"],
"exclude": ["node_modules"]
}

@dukeluo
Copy link

dukeluo commented Jun 22, 2024

根据 nextjs 的官方文档:https://nextjs.org/docs/pages/building-your-application/configuring/babel
还需要加入 "presets": ["next/babel"],可以解决这个问题:

{
  "presets": ["next/babel"],
  "plugins": []
}

但是,在 nextjs page router 运行时下会报出新的错误:

Global CSS cannot be imported from files other than your Custom <App>. Due to the Global nature of stylesheets, and to avoid conflicts, Please move all first-party global CSS imports to pages/_app.js. Or convert the import to Component-Level CSS (CSS Modules).

还是请官方出一份 nextjs 接入方案为好。

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants