Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >用SWC配置将NextJS@11迁移到NextJS@12

用SWC配置将NextJS@11迁移到NextJS@12
EN

Stack Overflow用户
提问于 2022-07-26 03:58:03
回答 1查看 723关注 0票数 1

我正在尝试将我的NextJS应用程序迁移到版本12。它使用babel可以正常工作,但我喜欢将环境更改为swc。

在生产生成过程中,我有以下错误:

./src/pages/_app.tsx模块未找到:无法解析‘@/index.scss’中的‘/project/src/page’

这些是我的配置文件:

tsconfig.json:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
{
      "compilerOptions": {
        "target": "es5",
        "lib": ["dom", "dom.iterable", "esnext"],
        "allowJs": true,
        "skipLibCheck": true,
        "strict": true,
        "forceConsistentCasingInFileNames": true,
        "noEmit": true,
        "esModuleInterop": true,
        "module": "esnext",
        "moduleResolution": "node",
        "resolveJsonModule": true,
        "isolatedModules": true,
        "jsx": "preserve",
        "baseUrl": ".",
        "paths": {
          "@assets/*": ["src/assets/*"],
          "@api": ["src/api"],
          "@i18n": ["src/scripts/i18n"],
          "@styles": ["./src/styles"],
          "@redux": ["./src/redux"],
          "@slices/*": ["./src/redux/slices/*"],
          "@utils": ["./src/utils"],
          "@root/*": ["./src/root/*"],
          "@hooks/*": ["./src/hooks/*"],
          "@schema/*": ["./src/types/schema/*"],
          "@configs": ["./src/app.config"],
          "@contexts/*": ["./src/contexts/*"],
          "@components/*": ["./src/components/*"],
          "@extensions/*": ["./src/scripts/extensions/*"],
          "~menu/*": ["./src/sections/menu/*"],
          "~order/*": ["./src/sections/order/*"],
          "~search/*": ["./src/sections/search/*"],
          "~growth/*": ["./src/sections/growth/*"],
          "~army/*": ["./src/sections/army/*"],
          "@jest-provider": ["./src/root/JestProvider"],
          "~service/*": ["./src/service/*"]
        }
      },
      "exclude": ["node_modules"],
      "include": ["next-env.d.ts", "**/*.ts", "**/*.tsx", "**/*.test.js"]
    }

next.config.js

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
const webpack = require('webpack')
const withPWA = require('next-pwa')
const pJson = require('./package.json')
const withPlugins = require('next-compose-plugins')
const setupENVs = require('./src/scripts/env.config')
const bundleAnalyzer = require('@next/bundle-analyzer')
const routesConfig = require('./src/scripts/routes.config')
const runtimeCaching = require('./src/scripts/sw.cache.config')
const {withSentryConfig} = require('@sentry/nextjs')
// const withTM = require('next-transpile-modules')(['design-system'])

const isDev = process.env.NODE_ENV !== 'production'

routesConfig(isDev)

const plugins = [new webpack.DefinePlugin(setupENVs())]

const securityHeaders = [
  {
    key: 'X-Frame-Options',
    value: 'SAMEORIGIN',
  },
]

const basConfig = (nextConfig = {}) => ({
  ...nextConfig,
  webpack(config, options) {
    config.plugins.push(...plugins)

    if (typeof nextConfig.webpack === 'function') {
      return nextConfig.webpack(config, options)
    }
    return config
  },
})

const withAnalyzer = bundleAnalyzer({
  enabled: process.env.ANALYZE === 'true',
})

let transpileModules

if (isDev) {
  transpileModules = basConfig()
} else if (process.env.ANALYZE === 'true') {
  transpileModules = basConfig(withAnalyzer())
} else {
  transpileModules = basConfig(
    withPWA({pwa: {dest: 'public', runtimeCaching, disable: true}})
  )
}

const moduleExports = withPlugins([transpileModules], {
  compiler: {
    styledComponents: {
      displayName: true,
      ssr: true,
    },
    removeConsole: true,
    // reactRemoveProperties: true,
  },
  env: {
    APP_VERSION: pJson.version,
  },
  async headers() {
    return [
      {
        source: '/(.*)',
        headers: securityHeaders,
      },
    ]
  },
  sentry: {
    disableClientWebpackPlugin: true,
    disableServerWebpackPlugin: true,
  },
  swcMinify: true,
  experimental: {
    forceSwcTransforms: true,
    swcTraceProfiling: true,
    swcMinifyDebugOptions: {
      compress: {
        defaults: true,
        side_effects: false,
      },
    },
    modularizeImports: {
      lodash: {
        transform: 'lodash/{{member}}',
      },
    },
  },
})

module.exports = withSentryConfig(moduleExports)

babel.config.json

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
{
  "presets": [
    [
      "next/babel",
      {
        "preset-env": {}
      }
    ]
  ],
  "plugins": [
    ["styled-components", {"ssr": true, "displayName": true}],
    [
      "module-resolver",
      {
        "root": "./src",
        "alias": {
          "@assets": "./src/assets",
          "@api": "./src/api",
          "@i18n": "./src/scripts/i18n",
          "@root": "./src/root",
          "@styles": "./src/styles",
          "@redux": "./src/redux",
          "@slices": "./src/redux/slices",
          "@hooks": "./src/hooks",
          "@utils": "./src/utils",
          "@schema": "./src/types/schema",
          "@contexts": "./src/contexts",
          "@configs": "./src/app.config",
          "@components": "./src/components",
          "@extensions": "./src/scripts/extensions",
          "~menu": "./src/sections/menu",
          "~order": "./src/sections/order",
          "~search": "./src/sections/search",
          "~growth": "./src/sections/growth",
          "~army": "./src/sections/army",
          "@jest-provider": "./src/root/JestProvider",
          "@mockData": "./__mocks__/data",
          "~service": "./src/service"
        },
        "extensions": [".js", ".jsx", ".ts", ".tsx", ".es", ".es6", ".mjs"]
      }
    ]
  ],
  "env": {
    "production": {
      "plugins": [["transform-remove-console"]]
    },
    "test": {
      "presets": [["@babel/preset-env", {"modules": false}], "next/babel"]
    }
  }
}

你能帮我一下吗?

EN

回答 1

Stack Overflow用户

发布于 2022-07-26 11:39:45

你应该考虑这两件事。

首先,正如next.js文档所述,您选择使用babel退出swc编译器。

新的Rust编译器是向后兼容的。如果您有一个现有的Babel配置,您将自动选择退出。

这是文档:https://nextjs.org/blog/next-12#faster-builds-and-fast-refresh-with-rust-compiler

其次,您的模块映射存在一些问题,因为样式不能位于“pages”文件夹下。

'/project/src/pages'

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73122994

复制
相关文章
EasyCVR开启音频后,视频调阅播放默认为静音的问题优化
EasyCVR基于云边端一体化架构,部署轻快、功能灵活,平台可支持多协议、多类型设备接入,包括:国标GB28181、RTMP、RTSP/Onvif、海康Ehome、海康SDK、大华SDK、宇视SDK等(具体见下图)。在视频能力上,可实现视频直播、录像、回放、检索、云存储、告警上报、语音对讲、电子地图、集群、智能分析以及平台级联等。
TSINGSEE青犀视频
2023/05/26
4090
如何将视频轻松转换为 GIF
有时看到一条有意思的视频想发到朋友圈,但朋友圈有限制时长,而且也不方便,这时可以把视频转GIF(再做成表情包也可以),再发到朋友圈或者微博(不用像视频一样需要等待审核)。
苏生不惑
2020/02/26
1.8K0
1342: [Baltic2007]Sound静音问题
1342: [Baltic2007]Sound静音问题 Time Limit: 5 Sec  Memory Limit: 162 MB Submit: 710  Solved: 307 [Submit][Status][Discuss] Description 静音问题 数字录音中,声音是用表示空气压力的数字序列描述的,序列中的每个值称为一个采样,每个采样之间间隔一定的时间。 很多声音处理任务都需要将录到的声音分成由静音隔开的几段非静音段。为了避免分成过多或者过少的非静音段,静音通常是这样定义的:m个采样的
HansBug
2018/04/10
8590
高清视频编码格式_如何将高清视频转化为蓝光
高清视频编码最常用的编码格式是MPEG2-TS、MPEG4、H.264和VC-1这四种算法。  
全栈程序员站长
2022/11/10
1.6K0
2019-12-1-微信小程序视频流静音后画面卡死问题研究
在静音期间试着使用ffplay进行播放,流能够正常播放,所以不存在推流端视频流丢帧的问题
黄腾霄
2020/06/10
8750
EasyPlayer如何将视频快照嵌入demo里?
TSINGSEE青犀视频EasyPlayer播放器系列属于非常开放的播放器项目,针对不同的协议衍生出了多个版本,如EasyPlayer.js、EasyPlayerPro等,而且用户还可以根据自己的需求,将其集成进流媒体平台,支持轻松调用接口或自主进行二次开发,实用性、稳定性都非常强。
TSINGSEE青犀视频
2022/01/25
5460
如何在远程会议的时候静音吃薯片?微软团队用AI去除视频噪声
上个月,Microsoft宣布,其与Slack,Facebook Workplace以及Google的Hangouts Chat的竞争对手Teams的每日活跃用户已超过4400万。这一里程碑却掩盖了其“稍后”发布的一些新功能。大部分功能都很简单明了:举手功能表明你有话要说;离线和低带宽支持,即使在网络连接不畅或没有网络情况下,也能阅读聊天消息并回复;以及将聊天弹出到一个单独窗口。其中还有一项实时噪声抑制功能吸引了大家眼球 - Microsoft演示AI如何在通话过程中减少让人分心的背景噪声。
大数据文摘
2020/04/28
1.2K0
如何在远程会议的时候静音吃薯片?微软团队用AI去除视频噪声
Instagram如何将视频编码时长缩短94%?
 点击上方“LiveVideoStack”关注我们 ▲扫描图中二维码或点击阅读原文▲ 了解音视频技术大会更多信息 编者按 Editor's note 眼看用户视频的增长将超过服务器的算力上限,既没有额外的服务器来支持,也不能对用户体验造成大的冲击,Instagram的工程师找到了两种编码过程中重复计算的部分,并将他们合二为一,如此便可节省可观的算力。他们是如何做到的呢? 作者:Ryan Peterman, Haixia Shi 译者:核子可乐 审校:Haixia Shi 在对效率的不断追求当中,Inst
LiveVideoStack
2023/04/04
9910
Instagram如何将视频编码时长缩短94%?
ubuntu 系统声音静音问题
在硬件设备中发现了系统声音重启被静音的问题,导致设备声音不可用。Bug情况暂未复现。无法从根本解决问题。只能想一个临时的问题。记录一下,临时的解决方案。主要还是通过 gnome-control-center 、pactl、amixer来解决。
何其不顾四月天
2023/03/10
2K0
【Android FFMPEG 开发】FFMPEG 初始化 ( 网络初始化 | 打开音视频 | 查找音视频流 )
FFMPEG 初始化流程 : FFMPEG 执行任何操作前 , 都需要初始化一些环境 , 及相关数据参数 ;
韩曙亮
2023/03/27
7300
TSINGSEE青犀视频智能视频监控EasyCVR如何将实时监控视频流分享出去?
开源EasyDarwin视频监控平台EasyCVR能在复杂的网络环境中,将分散的各类视频资源进行统一汇聚、整合、集中管理,在视频监控播放上,TSINGSEE青犀视频安防监控平台可支持1、4、9、16个画面窗口播放,可同时播放多路视频流,也能支持视频定时轮播。
TSINGSEE青犀视频
2023/08/02
2190
如何将数组的所有成员初始化为相同的值
C++ algorithm 有两个函数 – fill 和 fill_n,可以给数组赋值,
ClearSeve
2022/02/11
2.7K0
机器人如何将医疗带入未来(视频)
作者|Jennifer Levine 选文|孙强 编译|孙强 丁一 汪霞 让我们来谈谈机器人。我这儿说的并不是机器人接管世界、杀死人类的那种,而是正在帮助我们,将我们的生活变得更美好的那
大数据文摘
2018/05/21
6070
如何将录制的DOM转成视频文件
Dear,大家好,我是“前端小鑫同学”,😇长期从事前端开发,安卓开发,热衷技术,在编程路上越走越远~ 背景说明:      最近有在看GitHub上的rrweb项目,确实是一款DOM录制的神器,在使用文档中提供了很多我们会用到的场景和对应的示例,我们今天来看一下其中一个场景《转换为视频》,虽然rrweb直接回放的效果最佳但还是会遇到需要转为视频进行存储的要求,通过查看rrweb提供的rrvideo项目后决定写一下整个转换的过程,大致的流程图如下: 环境配置: 安
前端小鑫同学
2022/12/26
1.6K0
如何将录制的DOM转成视频文件
iOS如何判断设备处于静音模式
-(BOOL)silenced { #if TARGET_IPHONE_SIMULATOR // return NO in simulator. Code causes crashes for some reason. return NO; #endif CFStringRef state; UInt32 propertySize = sizeof(CFStringRef); AudioSessionInitialize(NULL, NULL, NULL, NULL); Aud
好派笔记
2021/10/29
1.6K0
视频流媒体服务器如何将视频直播转推到其他平台?
每一个行业做久了,都会有些小小的私心,就是把这个东西完善到更好,甚至到创造一个新东西的地步,我做视频行业也是这样的(我相信一定不是我一个人这么想的),所以如果有开发者提出什么需求,哪怕是目前不能满足的,我也会尽量满足。不过好在目前我们产品的功能已经趋于完善。
EasyNVR
2020/05/20
2.4K0
从 Android 静音看正确的查找 bug 的姿势
0、写在前面 没抢到小马哥的红包,无心回家了,回公司写篇文章安慰下自己TT。。话说年关难过,bug 多多,时间久了难免头昏脑热,不辨朝暮,难识乾坤。。。艾玛,扯远了,话说谁没踩过坑,可视大家都是如何从坑里爬出来的呢? 1、实现个静音的功能 话说,有那么一天, PM:『我这里有个需求,很简单很简单那种』 RD:『哦,需要做三天』 PM:『真的很简单很简单那种』 RD:『哦,现在需要做六天了』 对呀,静音功能多简单,点一下,欸,静音了;再点一下,欸,不静音了;再点一下,欸。。。 我一看 API,是挺简单的: p
腾讯Bugly
2018/03/23
1.1K0
【Android】自制静音App,解决他人手机外放问题
看到一个粉丝留言,吐槽舍友深夜手机外放,打扰别人休息,想设计一款软件阻止舍友行径。于是我就来简单设计一下。
zstar
2022/11/02
1.4K0
【Android】自制静音App,解决他人手机外放问题
音频缺失录制分析
RTMP Reader和Muxing各自包含音视频的AVCodecContext,共四个AVCodecContext
onexie
2020/01/20
1.4K0
点击加载更多

相似问题

CodeContracts问题

30

CodeContracts -误报

40

MissingFieldException与CodeContracts

13

理解TransactionScopeOptions: RequiresNew =禁止+必需?

10

特定通用接口的CodeContracts

10
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文