
CSS-in-JS 是一种将 CSS 样式嵌入 JavaScript 代码的技术。它让开发者用 JavaScript 语法编写 CSS 规则,为 React 应用提供更灵活、更模块化的样式管理方式。 这种方法在组件化架构盛行的今天尤其受欢迎,因为它能确保样式仅作用于特定组件,避免全局样式冲突。
在 React 中,CSS-in-JS 将样式与组件紧密绑定,提升样式的可维护性和可扩展性。 目前流行的 CSS-in-JS 库包括 styled-components、emotion 和 jss。
styled-components 是最流行的 CSS-in-JS 库之一。它允许在 JavaScript 文件中编写 CSS 代码,但样式作用域限制在各个组件内。
<code class="bash">npm install styled-components</code>
<code class="javascript">import React from 'react';
import styled from 'styled-components';
const Button = styled.button`
background-color: ${(props) => (props.primary ? 'blue' : 'gray')};
color: white;
padding: 10px 20px;
border: none;
border-radius: 5px;
cursor: pointer;
&:hover {
opacity: 0.8;
}
`;
const App = () => {
return (
<div>
<Button primary>Primary Button</Button>
<Button>Secondary Button</Button>
</div>
);
};
export default App;</code>styled.button 函数创建样式化的按钮组件。primary prop 动态控制按钮背景颜色。emotion 也是一个流行的 CSS-in-JS 库,提供强大的样式解决方案。它与 styled-components 类似,并额外提供性能优化和对服务器端渲染的更好支持。
立即学习“前端免费学习笔记(深入)”;
随着国民健身意识越来越强,各式各样的健身模式不断出现。瑜伽也受到了大众的喜爱,瑜伽行业发展越来越快,作为馆主,你还在微信群里让你的会员使用接龙的方式进行约课吗?你还在用传统的Excel进行排课吗?如果有一款小程序会员点一下就能约课,会不会让你惊喜、意外、激动——没错,瑜伽预约小程序就是为了解决馆主会员约课的痛点应运而生。功能包括瑜伽馆动态,瑜伽常识,瑜伽老师预约,瑜伽课程预约等模块。
0
<code class="bash">npm install @emotion/react @emotion/styled</code>
<code class="javascript">/** @jsxImportSource @emotion/react */
import { css } from '@emotion/react';
import styled from '@emotion/styled';
const buttonStyles = (primary) => css`
background-color: ${primary ? 'blue' : 'gray'};
color: white;
padding: 10px 20px;
border: none;
border-radius: 5px;
cursor: pointer;
&:hover {
opacity: 0.8;
}
`;
const Button = styled.button`
${(props) => buttonStyles(props.primary)}
`;
const App = () => {
return (
<div>
<Button primary>Primary Button</Button>
<Button>Secondary Button</Button>
</div>
);
};
export default App;</code>css 函数创建样式定义,通过 styled API 应用于组件。jss 另一个 CSS-in-JS 库,允许用 JavaScript 编写 CSS。它提供对样式更精细的控制,支持自定义主题和更高级的样式逻辑。
<code class="bash">npm install jss react-jss</code>
<code class="javascript">import React from 'react';
import { createUseStyles } from 'react-jss';
const useStyles = createUseStyles({
button: {
backgroundColor: (props) => (props.primary ? 'blue' : 'gray'),
color: 'white',
padding: '10px 20px',
border: 'none',
borderRadius: '5px',
cursor: 'pointer',
'&:hover': {
opacity: 0.8,
},
},
});
const Button = (props) => {
const classes = useStyles(props);
return <button className={classes.button}>{props.children}</button>;
};
const App = () => {
return (
<div>
<Button primary>Primary Button</Button>
<Button>Secondary Button</Button>
</div>
);
};
export default App;</code>createUseStyles 钩子生成样式。useStyles 钩子接收 props 并返回按钮的类名。CSS-in-JS 虽然有很多优点,但也存在一些挑战:
CSS-in-JS 是设计 React 应用的现代方法,它结合了 JavaScript 和 CSS 的优势。 通过 styled-components、emotion 或 jss 等库,开发者可在 JavaScript 文件中编写样式,提升代码库的模块化、性能和可维护性。 但在大型应用中,需要权衡 CSS-in-JS 的使用和潜在的性能影响。
以上就是CSS-in-JS:React 应用程序的现代样式的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号