首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >styled-jsx -可以在没有类名的情况下定义css规则吗?为什么动态解析的样式不起作用?

styled-jsx -可以在没有类名的情况下定义css规则吗?为什么动态解析的样式不起作用?
EN

Stack Overflow用户
提问于 2019-03-29 00:27:19
回答 1查看 1.1K关注 0票数 0

我有以下代码:

代码语言:javascript
复制
import React from 'react';
import MainTemplate from '../components/MainTemplate';
import { H1, Card } from '@blueprintjs/core';
import css from 'styled-jsx/css';

export default () => {
    const { className, styles } = css.resolve`
     { color: red; }
    `;
    return (
        <MainTemplate>
            {styles}
            <Card className={className}>
                <H1>Some header text!</H1>
            </Card>
        </MainTemplate>
    )
}

如您所见,我希望将一个className传递给外部Card组件。然而,我在dev工具中看到,有一个style元素添加到了head中,但它看起来好像里面有文本,而不是样式,也就是说,里面的语法没有突出显示。在结果中,样式不被应用。

所以我想知道我做错了什么?我使用了一个resolve标签,因为它是in the documentation

我还想知道,是否可以定义元素的样式,而不指定具体的标记名或类名?

我使用的是next.js,在开发和生产模式下都不会应用样式。

EN

回答 1

Stack Overflow用户

发布于 2019-03-29 13:06:21

事实证明,我只是在测试中使用了一个不合适的css规则-- colorH1的样式覆盖了,所以我没有看到效果。如果我使用widthheight,它工作得很好。所以这只是我的错误。

至于第二个问题,它在没有具体的标签或类的情况下工作得很好。甚至不需要添加括号,也就是说,下面的代码

代码语言:javascript
复制
const { className, styles } = css.resolve`height: 100%;`;
return (
    <MainTemplate>
        {styles}
        <Card className={className}>
            <H1>Плееры</H1>
        </Card>
    </MainTemplate>
)

效果也很好。

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

https://stackoverflow.com/questions/55402585

复制
相关文章

相似问题

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