3.2 KiB
3.2 KiB
id, challengeType, forumTopicId, title
id | challengeType | forumTopicId | title |
---|---|---|---|
5a24c314108439a4d4036181 | 6 | 301395 | 介绍内联样式 |
Description
className
属性将 class 应用于 JSX 元素,并将样式应用于样式表中的 class。另一种选择是使用内联样式,这在 ReactJS 开发中非常常见。
你将内联样式应用于 JSX 元素,类似于你在 HTML 中的操作方式,但有一些 JSX 差异。以下是 HTML 中内联样式的示例:
<div style="color: yellow; font-size: 16px">Mellow Yellow</div>
JSX 元素使用style
属性,但是由于 JSX 的传输方式,你不能将值设置为字符串
。相反,你应将其设置为 JavaScript对象
。这里有一个例子:
<div style={{color: "yellow", fontSize: 16}}>Mellow Yellow</div>
注意我们使用驼峰式命名的 "fontSize" 属性,这是因为 React 不会接受样式对象中的连字符。React 将在 HTML 中为我们应用正确的属性名称。
Instructions
div
中添加一个style
属性,使文本颜色为红色,字体大小为 72px。
请注意,你可以选择将字体大小设置为数字,省略单位 "px",或者将其写为 "72px"。
Tests
tests:
- text: 组件应该渲染一个<code>div</code>元素。
testString: assert((function() { const mockedComponent = Enzyme.mount(React.createElement(Colorful)); return mockedComponent.children().type() === 'div'; })());
- text: <code>div</code>元素应该是<code>红色</code>的。
testString: assert((function() { const mockedComponent = Enzyme.mount(React.createElement(Colorful)); return mockedComponent.children().props().style.color === 'red'; })());
- text: <code>div</code>元素的字体大小应为<code>72px</code>。
testString: assert((function() { const mockedComponent = Enzyme.mount(React.createElement(Colorful)); return (mockedComponent.children().props().style.fontSize === 72 || mockedComponent.children().props().style.fontSize === '72' || mockedComponent.children().props().style.fontSize === '72px'); })());
Challenge Seed
class Colorful extends React.Component {
render() {
return (
<div>Big Red</div>
);
}
};
After Test
ReactDOM.render(<Colorful />, document.getElementById('root'))
Solution
class Colorful extends React.Component {
render() {
return (
<div style={{color: "red", fontSize: 72}}>Big Red</div>
);
}
};