2018-10-10 22:03:03 +00:00
|
|
|
---
|
|
|
|
id: 5a24c314108439a4d4036181
|
2021-03-05 15:43:24 +00:00
|
|
|
title: 介绍内联样式
|
2018-10-10 22:03:03 +00:00
|
|
|
challengeType: 6
|
2020-09-17 16:13:42 +00:00
|
|
|
forumTopicId: 301395
|
2021-01-13 02:31:00 +00:00
|
|
|
dashedName: introducing-inline-styles
|
2018-10-10 22:03:03 +00:00
|
|
|
---
|
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
# --description--
|
2018-10-10 22:03:03 +00:00
|
|
|
|
2021-03-05 15:43:24 +00:00
|
|
|
还有其他复杂的概念可以为 React 代码增加强大的功能。 但是,你可能会想知道更简单的问题,比如:如何对在 React 中创建的 JSX 元素添加样式。 你可能知道,由于[将 class 应用于 JSX 元素的方式](/learn/front-end-libraries/react/define-an-html-class-in-jsx)与 HTML 中的使用并不完全相同。
|
2018-10-10 22:03:03 +00:00
|
|
|
|
2021-03-05 15:43:24 +00:00
|
|
|
如果从样式表导入样式,它就没有太大的不同。 使用 `className` 属性将 class 应用于 JSX 元素,并将样式应用于样式表中的 class。 另一种选择是使用内联样式,这在 ReactJS 开发中非常常见。
|
2018-10-10 22:03:03 +00:00
|
|
|
|
2021-03-05 15:43:24 +00:00
|
|
|
将内联样式应用于 JSX 元素,类似于在 HTML 中的操作方式,但有一些 JSX 差异。 以下是 HTML 中内联样式的示例:
|
2018-10-10 22:03:03 +00:00
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
`<div style="color: yellow; font-size: 16px">Mellow Yellow</div>`
|
2018-10-10 22:03:03 +00:00
|
|
|
|
2021-03-05 15:43:24 +00:00
|
|
|
JSX 元素使用 `style` 属性,但是由于 JSX 的编译方式,不能将值设置为 `string`(字符串)。 相反,你应将其设置为 JavaScript `object`(对象)。 这里有一个例子:
|
2018-10-10 22:03:03 +00:00
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
`<div style={{color: "yellow", fontSize: 16}}>Mellow Yellow</div>`
|
2018-10-10 22:03:03 +00:00
|
|
|
|
2021-03-05 15:43:24 +00:00
|
|
|
请注意如何驼峰拼写 `fontSize` 属性? 这是因为 React 不接受下划线分隔的样式对象。 React 将在 HTML 中编译为正确的属性名称。
|
2020-09-17 16:13:42 +00:00
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
# --instructions--
|
2018-10-10 22:03:03 +00:00
|
|
|
|
2021-03-05 15:43:24 +00:00
|
|
|
在代码编辑器的 `div` 中添加一个 `style` 属性,使文本颜色为红色,字体大小为 `72px`。
|
2018-10-10 22:03:03 +00:00
|
|
|
|
2021-03-05 15:43:24 +00:00
|
|
|
请注意,可以选择将字体大小设置为数字,省略单位 `px`,或者将其写为 `72px`。
|
2018-10-10 22:03:03 +00:00
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
# --hints--
|
2018-10-10 22:03:03 +00:00
|
|
|
|
2021-03-05 15:43:24 +00:00
|
|
|
组件应该渲染一个 `div` 元素。
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
|
|
```js
|
2020-12-16 07:37:30 +00:00
|
|
|
assert(
|
|
|
|
(function () {
|
|
|
|
const mockedComponent = Enzyme.mount(React.createElement(Colorful));
|
|
|
|
return mockedComponent.children().type() === 'div';
|
|
|
|
})()
|
|
|
|
);
|
2018-10-10 22:03:03 +00:00
|
|
|
```
|
|
|
|
|
2021-03-05 15:43:24 +00:00
|
|
|
`div` 元素的颜色应该是 `red`(红色)。
|
2018-10-10 22:03:03 +00:00
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
```js
|
|
|
|
assert(
|
|
|
|
(function () {
|
|
|
|
const mockedComponent = Enzyme.mount(React.createElement(Colorful));
|
|
|
|
return mockedComponent.children().props().style.color === 'red';
|
|
|
|
})()
|
|
|
|
);
|
|
|
|
```
|
2018-10-10 22:03:03 +00:00
|
|
|
|
2021-03-05 15:43:24 +00:00
|
|
|
`div` 元素的字体大小应为 `72px`。
|
2020-09-17 16:13:42 +00:00
|
|
|
|
2018-10-10 22:03:03 +00:00
|
|
|
```js
|
2020-12-16 07:37:30 +00:00
|
|
|
assert(
|
|
|
|
(function () {
|
|
|
|
const mockedComponent = Enzyme.mount(React.createElement(Colorful));
|
2020-09-17 16:13:42 +00:00
|
|
|
return (
|
2020-12-16 07:37:30 +00:00
|
|
|
mockedComponent.children().props().style.fontSize === 72 ||
|
|
|
|
mockedComponent.children().props().style.fontSize === '72' ||
|
|
|
|
mockedComponent.children().props().style.fontSize === '72px'
|
2020-09-17 16:13:42 +00:00
|
|
|
);
|
2020-12-16 07:37:30 +00:00
|
|
|
})()
|
|
|
|
);
|
2018-10-10 22:03:03 +00:00
|
|
|
```
|
2020-08-13 15:24:35 +00:00
|
|
|
|
2021-01-13 02:31:00 +00:00
|
|
|
# --seed--
|
|
|
|
|
|
|
|
## --after-user-code--
|
|
|
|
|
|
|
|
```jsx
|
|
|
|
ReactDOM.render(<Colorful />, document.getElementById('root'))
|
|
|
|
```
|
|
|
|
|
|
|
|
## --seed-contents--
|
|
|
|
|
|
|
|
```jsx
|
|
|
|
class Colorful extends React.Component {
|
|
|
|
render() {
|
|
|
|
return (
|
|
|
|
<div>Big Red</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
```
|
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
# --solutions--
|
|
|
|
|
2021-01-13 02:31:00 +00:00
|
|
|
```jsx
|
|
|
|
class Colorful extends React.Component {
|
|
|
|
render() {
|
|
|
|
return (
|
|
|
|
<div style={{color: "red", fontSize: 72}}>Big Red</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
```
|