From fd6d16c014337014b9d56f86e28d8f2f7850e408 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Carbon=20=E7=A2=B3=E8=8B=AF?= <2779066456@qq.com> Date: Wed, 1 Jan 2025 18:01:59 +0800 Subject: [PATCH] doc(cn): translate some previously English sections --- src/content/learn/adding-interactivity.md | 46 ++++++------- src/content/learn/describing-the-ui.md | 2 +- .../extracting-state-logic-into-a-reducer.md | 2 +- src/content/learn/index.md | 38 +++++------ .../javascript-in-jsx-with-curly-braces.md | 66 +++++++++---------- src/content/learn/keeping-components-pure.md | 18 ++--- src/content/learn/managing-state.md | 4 +- .../server/renderToPipeableStream.md | 2 +- 8 files changed, 89 insertions(+), 89 deletions(-) diff --git a/src/content/learn/adding-interactivity.md b/src/content/learn/adding-interactivity.md index 6c10c1eab4..363b4fc55e 100644 --- a/src/content/learn/adding-interactivity.md +++ b/src/content/learn/adding-interactivity.md @@ -138,75 +138,75 @@ export default function Gallery() { export const sculptureList = [{ name: 'Homenaje a la Neurocirugía', artist: 'Marta Colvin Andrade', - description: 'Although Colvin is predominantly known for abstract themes that allude to pre-Hispanic symbols, this gigantic sculpture, an homage to neurosurgery, is one of her most recognizable public art pieces.', + description: '尽管 Colvin 以暗示前西班牙符号的抽象主题而闻名,但这座巨大的雕塑是对神经外科的致敬,是她最知名的公共艺术作品之一。', url: 'https://i.imgur.com/Mx7dA2Y.jpg', - alt: 'A bronze statue of two crossed hands delicately holding a human brain in their fingertips.' + alt: '一尊双手交叉的青铜雕像,它的手指优雅地握住一个人类的大脑。' }, { name: 'Floralis Genérica', artist: 'Eduardo Catalano', - description: 'This enormous (75 ft. or 23m) silver flower is located in Buenos Aires. It is designed to move, closing its petals in the evening or when strong winds blow and opening them in the morning.', + description: '这朵巨大的银花(75 英尺或 23 米)位于布宜诺斯艾利斯。它并非静止的艺术,它能在晚上或强风吹拂时关闭花瓣,在早晨打开它们。', url: 'https://i.imgur.com/ZF6s192m.jpg', - alt: 'A gigantic metallic flower sculpture with reflective mirror-like petals and strong stamens.' + alt: '一个巨大的金属花卉雕塑,具有棱镜状的花瓣和坚固的雄蕊。' }, { name: 'Eternal Presence', artist: 'John Woodrow Wilson', - description: 'Wilson was known for his preoccupation with equality, social justice, as well as the essential and spiritual qualities of humankind. This massive (7ft. or 2,13m) bronze represents what he described as "a symbolic Black presence infused with a sense of universal humanity."', + description: '威尔逊以专注于平等、社会正义以及人类的基本和精神品质而闻名。这个巨大的(7 英尺或 2.13 米)青铜代表了他所描述的“一种象征性的黑人存在,注入了“普遍的人性意识”。', url: 'https://i.imgur.com/aTtVpES.jpg', - alt: 'The sculpture depicting a human head seems ever-present and solemn. It radiates calm and serenity.' + alt: '描绘人的头部的雕塑似乎从古至今都是庄严肃穆的。它们散发着平静和宁静。' }, { name: 'Moai', artist: 'Unknown Artist', - description: 'Located on the Easter Island, there are 1,000 moai, or extant monumental statues, created by the early Rapa Nui people, which some believe represented deified ancestors.', + description: '在复活节岛上,有 1000 个石像,或现存的纪念碑雕像,由早期的拉帕努伊人创造,一些人认为代表神化的祖先。', url: 'https://i.imgur.com/RCwLEoQm.jpg', alt: 'Three monumental stone busts with the heads that are disproportionately large with somber faces.' }, { name: 'Blue Nana', artist: 'Niki de Saint Phalle', - description: 'The Nanas are triumphant creatures, symbols of femininity and maternity. Initially, Saint Phalle used fabric and found objects for the Nanas, and later on introduced polyester to achieve a more vibrant effect.', + description: 'Nana 是一群自信奔放的人,也是女性气质和母性的象征。最初,Saint Phalle 使用布料和废弃物品来创作 Nana,后来又引入合成树脂以实现更具活力的效果。', url: 'https://i.imgur.com/Sd1AgUOm.jpg', - alt: 'A large mosaic sculpture of a whimsical dancing female figure in a colorful costume emanating joy.' + alt: '这是一件大型马赛克雕塑,展现了一个穿着绚丽服装、欢快舞蹈的女性形象,充满了喜悦和活力。' }, { name: 'Ultimate Form', artist: 'Barbara Hepworth', - description: 'This abstract bronze sculpture is a part of The Family of Man series located at Yorkshire Sculpture Park. Hepworth chose not to create literal representations of the world but developed abstract forms inspired by people and landscapes.', + description: '这座抽象的青铜雕塑是位于约克郡雕塑公园的《人类家族》系列的一部分。Hepworth 选择的不是创造世界的文字表现,而是受到人和景观的启发而发展出抽象的形式。', url: 'https://i.imgur.com/2heNQDcm.jpg', alt: 'A tall sculpture made of three elements stacked on each other reminding of a human figure.' }, { name: 'Cavaliere', artist: 'Lamidi Olonade Fakeye', - description: "Descended from four generations of woodcarvers, Fakeye's work blended traditional and contemporary Yoruba themes.", + description: "法基是四代木雕家的后代,他的作品融合了传统和当代约鲁巴主题。", url: 'https://i.imgur.com/wIdGuZwm.png', - alt: 'An intricate wood sculpture of a warrior with a focused face on a horse adorned with patterns.' + alt: '一个复杂的木制战士雕塑,马背上有一张严肃的脸,脸上装饰着图案。' }, { name: 'Big Bellies', artist: 'Alina Szapocznikow', - description: "Szapocznikow is known for her sculptures of the fragmented body as a metaphor for the fragility and impermanence of youth and beauty. This sculpture depicts two very realistic large bellies stacked on top of each other, each around five feet (1,5m) tall.", + description: "Szapocznikow 以她的肢体破损的雕塑而闻名,这些雕塑隐喻了年轻和美丽的脆弱和短暂。这座雕塑描绘了两个非常逼真的大肚皮,彼此叠放在一起,每个大约5英尺(1.5米)高。", url: 'https://i.imgur.com/AlHTAdDm.jpg', - alt: 'The sculpture reminds a cascade of folds, quite different from bellies in classical sculptures.' + alt: '这座雕塑让人联想到层叠的褶皱,与古典雕塑中的腹部截然不同。' }, { name: 'Terracotta Army', artist: 'Unknown Artist', - description: 'The Terracotta Army is a collection of terracotta sculptures depicting the armies of Qin Shi Huang, the first Emperor of China. The army consisted of more than 8,000 soldiers, 130 chariots with 520 horses, and 150 cavalry horses.', + description: '兵马俑是一组陶俑雕塑,描绘了中国第一个皇帝秦始皇的军队。军队由8000多名士兵、130辆战车、520匹马和150匹骑兵组成。', url: 'https://i.imgur.com/HMFmH6m.jpg', - alt: '12 terracotta sculptures of solemn warriors, each with a unique facial expression and armor.' + alt: '12 个庄严的武士兵马俑,每个都有独特的面部表情和盔甲。' }, { name: 'Lunar Landscape', artist: 'Louise Nevelson', - description: 'Nevelson was known for scavenging objects from New York City debris, which she would later assemble into monumental constructions. In this one, she used disparate parts like a bedpost, juggling pin, and seat fragment, nailing and gluing them into boxes that reflect the influence of Cubism’s geometric abstraction of space and form.', + description: 'Nevelson 以从纽约市的废墟中捡拾物体而闻名,后来她将这些碎片组装成纪念性建筑。在这幅画中,她使用了不同的部分,如床柱、杂耍的大头针和座椅碎片,将它们钉在盒子里并粘在一起,反映了立体主义对空间和形式的几何抽象的影响。', url: 'https://i.imgur.com/rN7hY6om.jpg', - alt: 'A black matte sculpture where the individual elements are initially indistinguishable.' + alt: '一种黑色哑光雕塑,其中单个元素最初无法区分。' }, { name: 'Aureole', artist: 'Ranjani Shettar', - description: 'Shettar merges the traditional and the modern, the natural and the industrial. Her art focuses on the relationship between man and nature. Her work was described as compelling both abstractly and figuratively, gravity defying, and a "fine synthesis of unlikely materials."', + description: 'Shettar 融合了传统与现代、自然与工业。她的艺术关注人与自然的关系。她的工作被描述为在抽象和比喻上都引人注目,挑战重力,以及“不太可能的材料的精细合成”。"', url: 'https://i.imgur.com/okTpbHhm.jpg', - alt: 'A pale wire-like sculpture mounted on concrete wall and descending on the floor. It appears light.' + alt: '一个苍白的线状雕塑安装在混凝土墙上,并下降到地板上。它看起来很轻。' }, { name: 'Hippos', - artist: 'Taipei Zoo', - description: 'The Taipei Zoo commissioned a Hippo Square featuring submerged hippos at play.', + artist: '台北动物园', + description: '台北动物园委托建造了河马广场,以水下河马为特色。', url: 'https://i.imgur.com/6o5Vuyu.jpg', - alt: 'A group of bronze hippo sculptures emerging from the sett sidewalk as if they were swimming.' + alt: '一组青铜河马雕塑从露台的人行道上出现,好像他们在游泳。' }]; ``` diff --git a/src/content/learn/describing-the-ui.md b/src/content/learn/describing-the-ui.md index 8776165d1a..75cb2fde9d 100644 --- a/src/content/learn/describing-the-ui.md +++ b/src/content/learn/describing-the-ui.md @@ -481,7 +481,7 @@ h2 { font-size: 20px; } let guest = 0; function Cup() { - // Bad: changing a preexisting variable! + // 不推荐的做法:直接修改一个已存在的变量。 guest = guest + 1; return

Tea cup for guest #{guest}

; } diff --git a/src/content/learn/extracting-state-logic-into-a-reducer.md b/src/content/learn/extracting-state-logic-into-a-reducer.md index 375fe8b86c..acfa1aae19 100644 --- a/src/content/learn/extracting-state-logic-into-a-reducer.md +++ b/src/content/learn/extracting-state-logic-into-a-reducer.md @@ -1201,7 +1201,7 @@ export default function ContactList({contacts, selectedId, dispatch}) {
  • diff --git a/src/content/learn/index.md b/src/content/learn/index.md index db580b69e7..21716c9309 100644 --- a/src/content/learn/index.md +++ b/src/content/learn/index.md @@ -34,7 +34,7 @@ React 组件是返回标签的 JavaScript 函数: ```js function MyButton() { return ( - + ); } ``` @@ -45,7 +45,7 @@ function MyButton() { export default function MyApp() { return (
    -

    Welcome to my app

    +

    欢迎来到我的应用

    ); @@ -62,7 +62,7 @@ export default function MyApp() { function MyButton() { return ( ); } @@ -70,7 +70,7 @@ function MyButton() { export default function MyApp() { return (
    -

    Welcome to my app

    +

    欢迎来到我的应用

    ); @@ -91,8 +91,8 @@ JSX 比 HTML 更加严格。你必须闭合标签,如 `
    `。你的组件 function AboutPage() { return ( <> -

    About

    -

    Hello there.
    How do you do?

    +

    关于

    +

    你好。
    最近怎么样?

    ); } @@ -111,7 +111,7 @@ function AboutPage() { 然后,你可以在一个单独的 CSS 文件中为它编写 CSS 规则: ```css -/* In your CSS */ +/* 在你的 CSS 文件中修改 */ .avatar { border-radius: 50%; } @@ -259,9 +259,9 @@ return ( ```js const products = [ - { title: 'Cabbage', isFruit: false, id: 1 }, - { title: 'Garlic', isFruit: false, id: 2 }, - { title: 'Apple', isFruit: true, id: 3 }, + { title: '卷心菜', isFruit: false, id: 1 }, + { title: '大蒜', isFruit: false, id: 2 }, + { title: '苹果', isFruit: true, id: 3 }, ]; export default function ShoppingList() { @@ -296,7 +296,7 @@ function MyButton() { return ( ); } @@ -354,7 +354,7 @@ import { useState } from 'react'; export default function MyApp() { return (
    -

    Counters that update separately

    +

    独立更新的计数器

    @@ -370,7 +370,7 @@ function MyButton() { return ( ); } @@ -449,7 +449,7 @@ export default function MyApp() { return (
    -

    Counters that update separately

    +

    独立更新的计数器

    @@ -457,7 +457,7 @@ export default function MyApp() { } function MyButton() { - // ... we're moving code from here ... + // ... 我们将把代码移动到这里 ... } ``` @@ -474,7 +474,7 @@ export default function MyApp() { return (
    -

    Counters that update together

    +

    共同更新的计数器

    @@ -490,7 +490,7 @@ export default function MyApp() { function MyButton({ count, onClick }) { return ( ); } @@ -512,7 +512,7 @@ export default function MyApp() { return (
    -

    Counters that update together

    +

    共同更新的计数器

    @@ -522,7 +522,7 @@ export default function MyApp() { function MyButton({ count, onClick }) { return ( ); } diff --git a/src/content/learn/javascript-in-jsx-with-curly-braces.md b/src/content/learn/javascript-in-jsx-with-curly-braces.md index 523df3c316..cb59caa8b2 100644 --- a/src/content/learn/javascript-in-jsx-with-curly-braces.md +++ b/src/content/learn/javascript-in-jsx-with-curly-braces.md @@ -82,7 +82,7 @@ JSX 是一种编写 JavaScript 的特殊方式。这为在大括号 `{ }` 中使 export default function TodoList() { const name = 'Gregorio Y. Zara'; return ( -

    {name}'s To Do List

    +

    {name}的待办事项列表

    ); } ``` @@ -190,16 +190,16 @@ const person = { export default function TodoList() { return (
    -

    {person.name}'s Todos

    +

    {person.name}'的待办事项

    Gregorio Y. Zara
    ); @@ -266,16 +266,16 @@ const person = { export default function TodoList() { return (
    -

    {person}'s Todos

    +

    {person}'的待办事项

    Gregorio Y. Zara
    ); @@ -314,16 +314,16 @@ const person = { export default function TodoList() { return (
    -

    {person.name}'s Todos

    +

    {person.name}'的待办事项

    Gregorio Y. Zara
    ); @@ -358,16 +358,16 @@ const person = { export default function TodoList() { return (
    -

    {person.name}'s Todos

    +

    {person.name}'的待办事项

    Gregorio Y. Zara
    ); @@ -401,16 +401,16 @@ const person = { export default function TodoList() { return (
    -

    {person.name}'s Todos

    +

    {person.name}'的待办事项

    Gregorio Y. Zara
    ); @@ -453,16 +453,16 @@ const person = { export default function TodoList() { return (
    -

    {person.name}'s Todos

    +

    {person.name}'的待办事项

    {person.name}
    ); @@ -504,16 +504,16 @@ const person = { export default function TodoList() { return (
    -

    {person.name}'s Todos

    +

    {person.name}'的待办事项

    {person.name}
    ); @@ -548,16 +548,16 @@ const person = { export default function TodoList() { return (
    -

    {person.name}'s Todos

    +

    {person.name}'的待办事项

    {person.name}
    ); diff --git a/src/content/learn/keeping-components-pure.md b/src/content/learn/keeping-components-pure.md index 39f795eba1..a6b162af8a 100644 --- a/src/content/learn/keeping-components-pure.md +++ b/src/content/learn/keeping-components-pure.md @@ -619,8 +619,8 @@ export default function App() { let [stories, setStories] = useState([...initialStories]) let time = useTime(); - // HACK: Prevent the memory from growing forever while you read docs. - // We're breaking our own rules here. + // 临时解决方案:防止在阅读文档时内存无限制增长。 + // 我们在这里违反了自己的规则。 if (stories.length > 100) { stories.length = 100; } @@ -633,7 +633,7 @@ export default function App() { textAlign: 'center', }} > -

    It is {time.toLocaleTimeString()} now.

    +

    现在是 {time.toLocaleTimeString()}。

    ); @@ -715,8 +715,8 @@ export default function App() { let [stories, setStories] = useState([...initialStories]) let time = useTime(); - // HACK: Prevent the memory from growing forever while you read docs. - // We're breaking our own rules here. + // 临时解决方案:防止在阅读文档时内存无限制增长。 + // 我们在这里违反了自己的规则。 if (stories.length > 100) { stories.length = 100; } @@ -729,7 +729,7 @@ export default function App() { textAlign: 'center', }} > -

    It is {time.toLocaleTimeString()} now.

    +

    现在是 {time.toLocaleTimeString()}。

    ); @@ -807,8 +807,8 @@ export default function App() { let [stories, setStories] = useState([...initialStories]) let time = useTime(); - // HACK: Prevent the memory from growing forever while you read docs. - // We're breaking our own rules here. + // 临时解决方案:防止在阅读文档时内存无限制增长。 + // 我们在这里违反了自己的规则。 if (stories.length > 100) { stories.length = 100; } @@ -821,7 +821,7 @@ export default function App() { textAlign: 'center', }} > -

    It is {time.toLocaleTimeString()} now.

    +

    现在是 {time.toLocaleTimeString()}。

    ); diff --git a/src/content/learn/managing-state.md b/src/content/learn/managing-state.md index 625a462ecb..60d61d633c 100644 --- a/src/content/learn/managing-state.md +++ b/src/content/learn/managing-state.md @@ -303,7 +303,7 @@ h3, p { margin: 5px 0px; } -## 对 state 进行保留和重置 {/*preserving-and-resetting-state*/} +## 对 State 进行保留和重置 {/*preserving-and-resetting-state*/} 当你重新渲染一个组件时, React 需要决定组件树中的哪些部分要保留和更新,以及丢弃或重新创建。在大多数情况下, React 的自动处理机制已经做得足够好了。默认情况下,React 会保留树中与先前渲染的组件树“匹配”的部分。 @@ -499,7 +499,7 @@ textarea { -阅读 **[对 state 进行保留和重置](/learn/preserving-and-resetting-state)** 来学习状态的生命周期以及如何控制它。 +阅读 **[对 State 进行保留和重置](/learn/preserving-and-resetting-state)** 来学习状态的生命周期以及如何控制它。 diff --git a/src/content/reference/react-dom/server/renderToPipeableStream.md b/src/content/reference/react-dom/server/renderToPipeableStream.md index a40c0892e3..ccec4566f5 100644 --- a/src/content/reference/react-dom/server/renderToPipeableStream.md +++ b/src/content/reference/react-dom/server/renderToPipeableStream.md @@ -104,7 +104,7 @@ export default function App() { - My app + 我的应用