我的编程空间,编程开发者的网络收藏夹
学习永远不晚

React使用emotion写css代码

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

React使用emotion写css代码

简介:

emotion是一个JavaScript库,使用emotion可以用写js的方式写css代码。在react中安装emotion后,可以很方便进行css的封装,复用。使用emotion后,浏览器渲染出来的标签是会加上一个css开头的标识。如下:截图中以css-开头的几个标签,就是使用emotion库后渲染出来的。

下面就从安装到使用,介绍下emotion在工程中的应用。

emotion的安装:


yarn add @emotion/react
yarn add @emotion/styled

新增普通css组件:

1,命名和组件一样,大写字母开头
2,styled后面跟html标签


// 引入emotion
import styled from "@emotion/styled”;

// 使用emotion 创建css组件
const Container = styled.div`
display: flex;
flex-direction: column;
align-items: center;
min-height: 100vh;
`;

//在html代码中使用css组件:
<Container>
// html代码
</Container>

给已存在组件加样式:

1,变量名首字符大写
2,将已经存在的组件作为参数传入styled
3,样式代码可以加参数


// Card 是antd已存在的组件
const ShadowCard = styled(Card)`
    width: 40rem;
    min-height: 56rem;
    padding: 3.2rem 4rem;
    border-radius: 0.3rem;
    box-sizing: border-box;
    box-shadow: rgba(0, 0, 0, 0.1) 0 0 10px;
    text-align: center;
`;

// 引入的图片,作为参数直接使用
import logo from "assets/logo.svg";

// 反引号可参照魔法字符串传入参数
const Header = styled.header`
background: url(${logo}) no-repeat center;
padding: 5rem 0;
background-size: 8rem;
width: 100%;
`;

提取公共的css组件

1, 反引号之前,接收泛型的参数, 可能用到的参数都要列出来
2, 取传进来的参数,用props来取,比如props.between, 可以用函数返回值给css属性赋值,css属性不渲染,返回值就是undefined


justify-content: ${(props) => (props.between ? "space-between" : undefined)};

3, 可以用css选择器
4,调用时,跟普通js组件一样使用,传参也相同


// 调用Row组件
<HeaderLeft gap={1}> 
//html代码
</HeaderLeft>
const HeaderLeft = styled(Row)``;


// 定义Row组件
export const Row = styled.div<{
  gap?: number | boolean;
  between?: Boolean;
  marginBottom?: number;
}>`
display: flex;
align-items: center;
justify-content: ${(props) => (props.between ? "space-between" : undefined)};

margin-bottom: ${(props) =>

props.marginBottom ? props.marginBottom + "px" : undefined};

> * {
margin-top: 0 !important;
margin-bottom: 0 !important;
margin-right: ${(props) =>

typeof props.gap === "number"
    ? props.gap + "rem"
    : props.gap
    ? "2rem"
    : undefined};
}
`;

写emotion行内样式

1,在组件的顶部写上 下面代码,告知当前组件用了emotion行内样式


2,行内样式的格式:css={ }


<Form css={{ marginBottom: "2rem" }} layout={"inline”}>
// html代码
</Form>

以上就是emotion的介绍和使用。(#^.^#)

以上就是React使用emotion写css代码的详细内容,更多关于React用emotion写css代码的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

React使用emotion写css代码

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

css代码怎么写

css 编写方法包括:语法选择器选择 html 元素,设置属性和值,形成 css 声明。组织形式有样式表、样式块和内联样式。选择器类型包括元素、类、id 和通配符选择器。常见属性示例有颜色、字体、大小、背景颜色和对齐。CSS 代码编写方法
css代码怎么写
2024-04-06

react写法实例代码分析

这篇文章主要介绍“react写法实例代码分析”,在日常操作中,相信很多人在react写法实例代码分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”react写法实例代码分析”的疑惑有所帮助!接下来,请跟着小编
2023-07-05

css代码写在哪里

css 代码可存储在以下三个位置:内联 css:写在 html 元素的 style 属性中,仅影响特定元素。内嵌 css:写在 html 文档的 元素内,影响所有页面元素。外部 css:存储在单独的 .css 文件中,通过 元素链接到
css代码写在哪里
2024-04-06

css样式代码怎么写

css 是一种用于描述 html 元素视觉呈现的样式表语言。语法结构:选择器:指定要应用样式的 html 元素属性:设置元素的视觉特性值:设置属性的具体值CSS 样式代码的编写CSS(层叠样式表)是一种样式表语言,用于描述 HTML 元素
css样式代码怎么写
2024-04-25

react dva实现的代码怎么编写

今天就跟大家聊聊有关react dva实现的代码怎么编写,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。dvadva是一个基于redux和redux-saga的数据流方案,然后为了简化
2023-06-25

使用技巧分享:带你轻松地编写CSS代码

CSS(层叠样式表)是用于网页设计的一种语言,它是HTML(超文本标记语言)的重要组成部分。使用CSS,您可以使网页更加吸引人,具有更好的可读性,更高的可访问性以及更好的浏览器兼容性。在本篇文章中,我们将介绍如何创建CSS,并提供一些实用的技巧来帮助您更轻松地编写CSS代码。1. 创建新的CSS文件在创建CSS之前,请确认已经创建了HTML文件并添加了引用CSS的代码片段。在H
2023-05-14

css背景图代码怎么写

这篇文章主要讲解了“css背景图代码怎么写”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“css背景图代码怎么写”吧!1. css背景图1.1 背景属性
2023-06-28

css中虚线代码怎么写

在 css 中创建虚线:使用语法:border: 1px dashed black;自定义样式:border: 1px dashed black 2px 5px;(2px 为虚线长度,5px 为间距)控制行为:使用 border-top/r
css中虚线代码怎么写
2024-05-23

编程热搜

目录