首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无法更改Chakra中的默认字体

无法更改Chakra中的默认字体
EN

Stack Overflow用户
提问于 2021-01-25 14:05:31
回答 3查看 9.6K关注 0票数 3

第一次使用脉轮,并试图将默认字体更改为Chakra中的,但没有取得任何效果。是否有一个导入(分配了新主题)将其作为道具传递给ChakraProvider,但代码中没有发生任何事情。

index.js

代码语言:javascript
复制
import {extendTheme, ChakraProvider} from "@chakra-ui/react"

const customTheme = {
    fonts: {
        body: 'Times New Roman, sans-serif',
        heading: 'Times New Roman, sans-serif',
        mono: 'Times New Roman, sans-serif', }


const theme = extendTheme({customTheme})

ReactDOM.render(
    <React.StrictMode>
        <ChakraProvider theme={theme}>
            <App/>
        </ChakraProvider>
    </React.StrictMode>,
    document.getElementById('root')
);

我的文本组件似乎没有改变

代码语言:javascript
复制
import {Text} from '@chakra-ui/react'
<Text> Some text </Text>
EN

回答 3

Stack Overflow用户

发布于 2021-06-06 23:58:38

您可以在他们的文档上看到如何做到这一点。

  1. 创建一个theme.js文件,在该文件中我们将覆盖默认主题

在此处添加以下内容:

代码语言:javascript
复制
// importing the required chakra libraries
import { theme as chakraTheme } from '@chakra-ui/react'
import { extendTheme } from "@chakra-ui/react"

// declare a variable for fonts and set our fonts. I am using Inter with various backups but you can use `Times New Roman`. Note we can set different fonts for the body and heading.
const fonts = {
  ...chakraTheme.fonts,
  body: `Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol"`,
  heading: `Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol"`
}

// declare a variable for our theme and pass our overrides in the e`xtendTheme` method from chakra
const customTheme = extendTheme(overrides)

// export our theme
export default customTheme
  1. 在主题中包装我们的应用程序
代码语言:javascript
复制
// import our theme
import theme from '../customTheme.js'

// wrap our application with the theme. This can be passed onto the ChakraProvider.
<ChakraProvider theme={theme}>
  <App />
</ChakraProvider>
票数 5
EN

Stack Overflow用户

发布于 2022-05-18 12:18:12

我可以看出您的extendTheme用法是错误的。

const theme = extendTheme({customTheme})花括号不应该在那里。这基本上是指:

代码语言:javascript
复制
const theme = {
   customTheme: { // <-- it adds the custom theme as a customTheme property
      fonts: {
         ...
      }
   }
}

只要去掉花括号,你就可以走了!

票数 0
EN

Stack Overflow用户

发布于 2022-09-07 19:17:10

这适用于我使用脉轮和nextjs。

创建一个文件styles.css

代码语言:javascript
复制
@font-face {
  font-family: "Font";
  src: url('../your/path/Font.woff');
  font-weight: normal;
  font-style: normal;
}

在你的index.js

代码语言:javascript
复制
import '../path/styles/styles.css'
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65886321

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档