React百日学习计划-Grok3
关键点
- 研究表明,100天内学习React是可行的,尤其是你已有HTML、JS和CSS基础。
- 该计划包括基础知识、hooks、状态管理、路由、样式化及综合项目,适合初学者。
- 建议每天花2-3小时学习,结合免费教程和社区支持。
开始学习
学习React的最佳方式是从一个结构化的100天计划开始,利用你的HTML、JS和CSS技能。每天专注编码、教程和小项目,确保稳步进步。推荐资源包括30 Days Of React挑战,适合初学者分步学习。
每日承诺
目标是每天投入2-3小时,专注于实践和理解概念,如通过构建待办事项列表练习组件和状态管理。
资源和支持
- 使用免费资源如freeCodeCamp React课程和官方React文档。
- 考虑付费课程如Udemy的“React - The Complete Guide”(链接)。
- 加入Reddit的r/reactjs或React Discord社区,获取支持和反馈。
针对React初学者的100天学习计划详细说明
本指南为具备初级HTML、JavaScript和CSS知识的人设计,旨在100天内掌握React。鉴于你对HTML、JS和CSS的熟悉程度,你已经拥有一个坚实的基础,但学习React会引入新的概念,如JSX、hooks和状态管理。研究表明,结构化的、基于项目的方法,结合每天一致的练习,对于初学者掌握React非常有效。该计划利用了流行的资源和社区反馈,量身定制了一条与你的技能水平和目标相符的学习路径。
背景和理由
React,由Facebook于2013年开发,广泛用于通过可重用组件构建单页应用程序。鉴于你对HTML、JS和CSS的熟悉,你有坚实的基础,但学习React会引入如JSX、hooks和状态管理的新概念。研究表明,结合理论学习、项目实践和社区参与的结构化方法,对技能习得特别有效,尤其是对初学者。
详细100天计划
计划分为六个阶段,每个阶段都有特定的目标、主题和行动计划。以下是详细分解:
阶段1:第1-30天 - 掌握React基础
- 目标: 在React基础知识上建立坚实的基础,并开始创建小型项目。
- 关键主题:
- React介绍及其益处。
- 设置开发环境,通常使用Create React App。
- 理解JSX,JavaScript的语法扩展。
- 学习函数式和类组件。
- 管理props(传递给组件的数据)和state(组件级数据)。
- 处理列表和keys以渲染动态数据。
- 基本生命周期方法,尽管现代React强调hooks。
- 行动计划:
- 跟随“30 Days Of React挑战”(30 Days Of React),这是一个为具备HTML、CSS和JS知识的初学者设计的分步指南,包括实践练习和真实项目。
- 构建小型项目,如待办事项列表或简单计算器,以练习概念。
- 资源:
- 30 Days Of React:免费、全面的每日任务挑战。
- 官方React文档:用于参考和深入学习。
- freeCodeCamp React课程:为初学者提供互动课程。
阶段2:第31-45天 - 深入学习React Hooks
- 目标: 掌握React Hooks,这是现代函数式组件开发的关键。
- 关键主题:
- useState用于管理组件状态。
- useEffect用于处理副作用,如数据获取。
- useContext用于在不进行prop钻取的情况下在组件之间共享状态。
- 创建自定义hooks以重用逻辑。
- 行动计划:
- 在专注于hooks的教程和练习上花费时间,使用如freeCodeCamp的React Hooks教程的资源。
- 构建一个小型项目,如使用useEffect获取数据的天气应用。
- 资源:
- freeCodeCamp的React Hooks教程:带有示例的全面指南。
- React文档上的Hooks:官方指南。
阶段3:第46-60天 - 学习状态管理与Redux
- 目标: 理解如何在更大、更复杂的应用程序中管理状态使用Redux。
- 关键主题:
- Redux的基础,包括动作、reducer和store。
- 将Redux与React连接以管理状态。
- 行动计划:
- 跟随一个Redux教程并构建一个简单的应用,如购物车,练习状态管理。
- 专注于理解Redux如何补充React以实现可扩展的应用程序。
- 资源:
- freeCodeCamp的Redux入门指南:实用示例。
- Udemy的“React - The Complete Guide”:包括Redux,评价很高。
阶段4:第61-75天 - 学习路由与React Router
- 目标: 掌握单页应用程序中的导航使用React Router。
- 关键主题:
- 为客户端路由设置React Router。
- 处理路由、嵌套路由和动态路由。
- 使用Link和NavLink组件进行导航。
- 行动计划:
- 构建一个多页面应用,如带有导航的简单博客,练习路由概念。
- 实验不同的路由场景以理解最佳实践。
- 资源:
- React Router文档:官方指南,全面示例。
- freeCodeCamp的React Router教程:初学者的分步指南。
阶段5:第76-90天 - 探索React中的样式化
- 目标: 学习有效地为React组件样式化以创建视觉上吸引人的应用程序。
- 关键主题:
- CSS-in-JS解决方案如styled-components。
- CSS模块用于范围样式。
- 使用传统CSS进行全局样式化,包括最佳实践。
- 行动计划:
- 在构建项目时尝试不同的样式化方法,如带有自定义样式的仪表板。
- 比较和对比方法以找到适合你的工作流程的方法。
- 资源:
- styled-components文档:用于CSS-in-JS。
- freeCodeCamp的React应用样式化教程:涵盖各种技术。
阶段6:第91-100天 - 构建综合项目
- 目标: 将所学概念应用于更大的、真实世界的项目,从而巩固你的React技能。
- 关键主题:
- 整合组件、hooks、路由、状态管理和样式化。
- 可选:使用如JSONPlaceholder或Firebase的API进行后端集成。
- 行动计划:
- 选择一个项目想法,如带有用户身份验证的博客应用或任务管理应用。
- 在最后10天中构建并完善它,专注于最佳实践和优化。
- 资源:
- GitHub上的项目想法:寻找灵感。
- freeCodeCamp的React项目想法:从初级到高级。
附加提示
- 每日练习: 每天至少花2-3小时编码,确保一致性,与100天代码挑战一致。
- 社区参与: 加入如Reddit的r/reactjs或React Discord社区,参与讨论,获取支持。
- 代码审查: 在GitHub或CodePen分享项目,获取反馈,改进。
- 挑战自己: 参加LeetCode或HackerRank的编码挑战,提升问题解决技能。
推荐资源表
以下是每个阶段的关键资源总结,确保你可以访问免费和付费选项:
阶段 | 资源类型 | 详情 | URL |
---|---|---|---|
基础 (第1-30天) | 挑战 | 30 Days Of React,分步指南适用于初学者 | 30 Days Of React |
基础 (第1-30天) | 课程 | freeCodeCamp React课程,互动课 | freeCodeCamp React |
Hooks (第31-45天) | 教程 | freeCodeCamp的React Hooks教程,带有示例 | React Hooks教程 |
状态管理 (第46-60天) | 指南 | freeCodeCamp的Redux入门,实用示例 | Redux入门 |
路由 (第61-75天) | 文档 | React Router官方指南,全面示例 | React Router |
样式化 (第76-90天) | 文档 | styled-components,用于CSS-in-JS | styled-components |
综合项目 (第91-100天) | 项目灵感 | GitHub上的React项目主题,综合项目灵感 | React项目灵感 |
关键引用
- 30 Days Of React 30天学习React挑战指南
- freeCodeCamp React课程 前端库React学习路径
- Udemy React完整指南 包括Hooks React Router Redux
- 官方React文档 入门和基础指南
- freeCodeCamp React Hooks教程 React Hooks介绍
- freeCodeCamp Redux入门 初学者实用指南
- React Router官方指南 React路由器文档
- styled-components文档 CSS in JS技术指南
- GitHub主题 React项目灵感集锦
- freeCodeCamp React Router教程 学习React路由指南
- freeCodeCamp React应用样式化教程 使用Tailwind和styled-components
- freeCodeCamp React初学者项目 实践项目灵感
相关文章:
React百日学习计划-Grok3
关键点 研究表明,100天内学习React是可行的,尤其是你已有HTML、JS和CSS基础。该计划包括基础知识、hooks、状态管理、路由、样式化及综合项目,适合初学者。建议每天花2-3小时学习,结合免费教程和社区支持。 开始学习 学习React…...
Android NDK 高版本交叉编译:为何无需配置 FLAGS 和 INCLUDES
引言:NDK 交叉编译的演进 Android NDK(Native Development Kit)是开发高性能C/C代码的核心工具链,而交叉编译(在x86主机上生成ARM架构代码)一直是NDK的核心功能。过去,开发者需要手动配置大量编…...
Java详解LeetCode 热题 100(15):LeetCode 189. 轮转数组(Rotate Array)详解
文章目录 1. 题目描述2. 理解题目3. 解法一:使用额外数组3.1 思路3.2 Java代码实现3.3 代码详解3.4 复杂度分析3.5 适用场景 4. 解法二:环状替换法(原地算法)4.1 思路4.2 Java代码实现4.3 代码详解4.4 复杂度分析4.5 陷阱与注意事…...
出于PCB设计层面考虑,连排半孔需要注意哪些事项?
通过拼接作为后处理运行,用拼接联排半孔填充铜的自由区域。为了使通缝成为可能,必须在不同的层上有重叠的铜区域连接到指定的网上。铜的支持区域包括填充、多边形和动力平面。 高电流对电路板的潜在负面影响的另一个例子是电路板结构的物理失效。制造原始…...
JIT+Opcache如何配置才能达到性能最优
首先打开php.ini文件,进行配置 1、OPcache配置 ; 启用OPcache opcache.enable1; CLI环境下启用OPcache(按需配置) opcache.enable_cli0; 预加载脚本(PHP 7.4,加速常用类) ; opcache.preload/path/to/prel…...
VR和眼动控制集群机器人的方法
西安建筑科技大学信息与控制工程学院雷小康老师团队联合西北工业大学航海学院彭星光老师团队,基于虚拟现实(VR)和眼动追踪技术实现了人-集群机器人高效、灵活的交互控制。相关研究论文“基于虚拟现实和眼动的人-集群机器人交互方法” 发表于信…...
LabVIEW与PLC通讯程序S7.Net.dll
下图中展示的是 LabVIEW 环境下通过调用S7.Net.dll 组件与西门子 PLC 进行通讯的程序。LabVIEW 作为一种图形化编程语言,结合S7.Net.dll 的.NET 组件优势,在工业自动化领域中可高效实现与 PLC 的数据交互,快速构建工业监控与控制应用。相较于…...
【华为】现场配置OSPF
原创:厦门微思网络 实验目的 1、了解OSPF的运行原理 2、掌握OSPF的配置方法 实验拓扑 实验需求 1、根据实验拓扑图,完成设备的基本配置; 2、分别在R1、R2、R3上创建Loopback0接口,IP地址分别是1.1.1.1/32、2.2.2.2/32、3.3.3.…...
STM32-DMA数据转运(8)
目录 一、简介 二、存储器映像 三、DMA框图编辑 四、DMA基本结构 五、两个数据转运的实例 一、简介 直接存储器存取简称DMA(Direct Memory Access),它是一个数据转运小助手,主要用来协助CPU,完成数据转运的工作…...
课题推荐——低成本地磁导航入门,附公式推导和MATLAB例程运行演示
地磁导航利用地球磁场的自然特性,通过感知磁场变化,帮助机器人或无人设备实现定位和导航。相比于 GPS、激光雷达等导航方法,地磁导航具有以下优势: 低成本:使用地磁传感器(如电子罗盘)ÿ…...
微信小程序学习之底部导航栏
首先,我们在app.json中添加4个页面, "pages": ["pages/index/index","pages/category/category","pages/cart/cart","pages/user/user"], 其次我们把8张图片放到imaes文件夹下, 图标可…...
c++ std库中的文件操作学习笔记
1. 概述 C标准库提供了 头文件中的几个类来进行文件操作,这些类封装了底层的文件操作,提供了面向对象和类型安全的接口,使得文件读写更加便捷和高效。主要的文件流类包括: std::ifstream:用于从文件中读取数据。 st…...
多臂赌博机:探索与利用的平衡艺术
1. 引言 在机器学习领域,多臂赌博机(Multi-Armed Bandit,MAB)问题是强化学习的一个经典且基础的模型。这个名称源于赌场中的"单臂老虎机"(One-armed Bandit),因为这种赌博机器像强盗…...
分布式异步强化学习框架训练32B大模型:INTELLECT-2
INTELLECT-2 模型详解 一、模型概述 INTELLECT-2 是一个拥有 320 亿参数的语言模型,其训练采用了一种创新的方式,即通过社区贡献的分布式、无需许可的 GPU 资源进行强化学习训练。该模型基于 qwen2 架构构建,因此与 vllm 或 sglang 等流行库…...
HTML应用指南:利用POST请求获取全国京东快递服务网点位置信息
京东快递作为中国领先的智能供应链与综合物流服务提供商,自2007年成立以来,始终致力于通过技术创新与高效运营,为客户提供安全、可靠、快速的物流解决方案。京东快递依托京东集团的强大资源支持,凭借其自营仓储、干线运输、末端配送一体化的物流网络,在激烈的市场竞争中脱…...
通过POI实现对word基于书签的内容替换、删除、插入
一、基本概念 POI:即Apache POI, 它是一个开源的 Java 库,主要用于读取 Microsoft Office 文档(Word、Excel、PowerPoint 等),修改 或 生成 Office 文档内容,保存 为对应的二进制或 XML 格式&a…...
git进行版本控制时遇到Push cannot contain secrets的解决方法
git进行版本控制,push遇到Push cannot contain secrets的解决方法 最近在项目开发过程中,我遇到了一个让我头疼不已的问题。 问题的出现 一开始,我的项目远程仓库连接的是 Gitee,在开发过程中一切都很顺利,我也习惯…...
Java GUI 开发之旅:Swing 组件与布局管理的实战探索
在编程的世界里,图形用户界面(GUI)设计一直是提升用户体验的关键环节。Java 的 Swing 库为我们提供了强大的工具来构建跨平台的 GUI 应用。今天,我将通过一次实验,分享如何使用 Java Swing 开发一个功能丰富的 GUI 应用…...
OpenVLA (2) 机器人环境和环境数据
文章目录 前言1 BridgeData V21.1 概述1.2 硬件环境 2 数据集2.1 场景与结构2.2 数据结构2.2.1 images02.2.2 obs_dict.pkl2.2.3 policy_out.pkl 前言 按照笔者之前的行业经验, 数据集的整理是非常重要的, 因此笔者这里增加原文中出现的几个数据集和环境的学习 1 BridgeData V…...
【Ansible】基于windows主机,采用NTLM+HTTPS 认证部署
我们现在准备Linux centos7(Ansible控制机)和Windows(客户机)环境下的详细部署步骤: 一、Windows客户机配置 1. 准备SSL证书 1.1 生成自签名证书(测试用) 以管理员身份打开PowerShell&#…...
React19源码系列之 API(react-dom)
API之 preconnect preconnect – React 中文文档 preconnect 函数向浏览器提供一个提示,告诉它应该打开到给定服务器的连接。如果浏览器选择这样做,则可以加快从该服务器加载资源的速度。 preconnect(href) 一、使用例子 import { preconnect } fro…...
鸿蒙Next开发 获取APP缓存大小和清除缓存
1. 鸿蒙Next开发 获取APP缓存大小和清除缓存 1.1. 介绍 1.1.1. 文件系统分类 在最新的Core File Kit套件中,按文件所有者的不同。分为如下三类: (1)应用文件:文件所有者为应用,包括应用安装文件、应用…...
PNG转ico图标(支持圆角矩形/方形+透明背景)Python脚本 - 随笔
摘要 在网站开发或应用程序设计中,常需将高品质PNG图像转换为ICO格式图标。本文提供一份基于Pillow库实现的,能够完美保留透明背景且支持导出圆角矩形/方形图标的格式转换脚本。 源码示例 圆角方形 from PIL import Image, ImageDraw, ImageOpsdef c…...
『大模型笔记』Langchain作者Harrison Chase专访:环境智能体与全新智能体收件箱
Langchain作者Harrison Chase专访:环境智能体与全新智能体收件箱 文章目录 摘要访谈内容什么环境智能体为什么要探索环境智能体怎么让人类能更方便地和环境智能体互动参考文献摘要 LangChain 的 CEO Harrison Chase 提出了_“环境智能体”(Ambient Agents)的概念,这是一种…...
GPT( Generative Pre-trained Transformer )模型:基于Transformer
GPT是由openAI开发的一款基于Transformer架构的预训练语言模型,拥有强大的生成能力和多任务处理能力,推动了自然语言处理(NLP)的快速发展。 一 GPT发展历程 1.1 GPT-1(2018年) 是首个基于Transformer架构…...
游戏引擎学习第275天:将旋转和剪切传递给渲染器
回顾并为今天的内容定下基调 我们认为在实现通用动画系统之前,先学习如何手写动画逻辑是非常有价值的。虽然加载和播放预设动画是合理的做法,尤其是在团队中有美术人员使用工具制作动画的情况下更是如此,但手动编写动画代码能让我们更深入理…...
conda 输出指定python环境的库 输出为 yaml文件
conda 输出指定python环境的库 输出为 yaml文件。 有时为了项目部署,需要匹配之前的python环境,需要输出对应的python依赖库。 假设你的目标环境名为 myenv,运行以下命令: conda env export -n myenv > myenv_environment.ym…...
ES6 语法
扩展运算符 … 口诀:三个点,打散数组,逐个放进去 例子: let arr [1, 2];let more [3, 4];arr.push(...more); // arr 变成 [1, 2, 3, 4]解构赋值 口诀:左边是变量,右边是值,一一对应 例子&…...
BFS算法篇——打开智慧之门,BFS算法在拓扑排序中的诗意探索(下)
文章目录 引言一、课程表1.1 题目链接:https://leetcode.cn/problems/course-schedule/description/1.2 题目分析:1.3 思路讲解:1.4 代码实现: 二、课程表||2.1 题目链接:https://leetcode.cn/problems/course-schedul…...
While语句数数字
import java.util.Scanner;public class Hello {public static void main(String[] args) {Scanner in new Scanner(System.in);int number in.nextInt();int count 0;while( number > 0 ){number number / 10;count count 1;}System.out.println(count);} }...
G1JVM内存分配机制详解
为什么堆内存不是预期的3G? 当您设置-XX:MaxRAMPercentage75时,JVM并不会简单地将容器内存(4G)的75%全部分配给堆,原因如下: 计算基准差异: 百分比是应用于"可用物理内存"而非"容器总内存" &q…...
“端 - 边 - 云”三级智能协同平台的理论建构与技术实现
摘要 随着低空经济与智能制造的深度融合,传统集中式云计算架构在实时性、隐私保护和资源效率上的瓶颈日益凸显。本文提出“端 - 边 - 云”三级智能协同平台架构,以“时空 - 资源 - 服务”三维协同理论为核心,构建覆盖终端感知、边缘计算、云端…...
【UAP】《Empirical Upper Bound in Object Detection and More》
Borji A, Iranmanesh S M. Empirical upper bound in object detection and more[J]. arXiv preprint arXiv:1911.12451, 2019. arXiv-2019 文章目录 1、Background and Motivation2、Related Work3、Advantages / Contributions4、Experimental Setup4.1、Benchmarks Dataset…...
Web Service及其实现技术(SOAP、REST、XML-RPC)介绍
一.概述 1.Web Service(Web 服务) Web Service 由万维网联盟 (W3C) 定义为一种软件系统,旨在支持通过网络进行可互操作的计算机间交互。 广义概念:基于 Web 技术(如 HTTP 协议)的跨平台、跨语言通信机制…...
基于Spring Boot+Layui构建企业级电子招投标系统实战指南
一、引言:重塑招投标管理新范式 在数字经济浪潮下,传统招投标模式面临效率低、透明度不足、流程冗长等痛点。本文将以Spring Boot技术生态为核心,融合Mybatis持久层框架、Redis高性能缓存及Layui前端解决方案,构建一个覆盖招标代理…...
【嵌入式】记一次解决VScode+PlatformIO安装卡死的经历
PlatformIO 是开源的物联网开发生态系统。提供跨平台的代码构建器、集成开发环境(IDE),兼容 Arduino,ESP8266和mbed等。 开源库地址:https://github.com/platformio 在 VScode 中配置 PlatformIO 插件,记录…...
抗量子计算攻击的数据安全体系构建:从理论突破到工程实践
在“端 - 边 - 云”三级智能协同理论中,端 - 边、边 - 云之间要进行数据传输,网络的安全尤为重要,为了实现系统总体的安全可控,将构建安全网络。 可先了解我的前文:“端 - 边 - 云”三级智能协同平台的理论建构与技术实…...
【FMMT】基于模糊多模态变压器模型的个性化情感分析
遇到很难的文献看不懂,不应该感到气馁,应该激动,因为外审估计也看不太懂,那么学明白了可以吓唬他 缺陷一:输入依赖性与上下文建模不足 缺陷描述: 传统自注意力机制缺乏因果关系,难以捕捉序列历史背景多模态数据间的复杂依赖关系未被充分建模CNN/RNN类模型在…...
力扣Hot100(Java版本)
1. 哈希 1.1 两数之和 题目描述: 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。 你可以假设每种输入只会对应一个答案,并且你不能使用两次相同…...
Stream流简介、常用方法
Stream流的三类方法 获取Stream流 创建一条流水线,并把数据放到流水线上准备进行操作 中间方法 流水线上的操作一次操作完毕之后,还可以继续进行其他操作 终结方法 一个Stream流只能有一个终结方法是流水线上的最后一个操作 生成Stream流的方式 Collec…...
C# 集成 FastDFS 完整指南
1. 环境准备 (1) 安装 FastDFS 服务端 部署 Tracker 和 Storage 节点,确保服务正常运行。 配置 tracker_server 地址(如 192.168.1.100:22122)。 (2) 添加 NuGet 包 通过 NuGet 安装 FastDFS 客户端库: Install-Pack…...
重构门店网络:从“打补丁“到“造地基“的跨越
您是否遇到过这样的窘境? 新店开张要等一周,就为装根网线; 偏远地区门店三天两头断网,顾客排长队却结不了账; 总部想看实时数据,结果收到一堆乱码报错; 总部ERP系统升级,2000家门…...
TI的ADS1291代替芯片LH001-99
血管疾病严重威胁人类生命健康安全,随着人口老龄化进程的加快和社会压力等因素的增加,患病率正呈现逐年上升趋势,并且越来越年轻化。然而,心血管疾病大多由器官器质性病变引起,一旦患病很难完全康复,需要进…...
NPOI 操作 Word 文档
管理 NuGet 程序包 # word操作 NPOI# 图片操作 SkiaSharp Controller代码 using Microsoft.AspNetCore.Mvc; using NPOI.Util; using NPOI.XWPF.Model; using NPOI.XWPF.UserModel; using SkiaSharp;namespace WebApplication2.Controllers {[Route("api/Npoi/[action]…...
css3基于伸缩盒模型生成一个小案例
css3基于伸缩模型生成一个小案例 在前面学习了尚硅谷天禹老师的css3内容后,基于伸缩盒模型做的一个小案例,里面使用了 flex 布局,以及主轴切换,以及主轴平分等特性,分为使用css3 伸缩盒模型方式,已经传统的…...
精简大语言模型:用于定制语言模型的自适应知识蒸馏
Streamlining LLMs: Adaptive Knowledge Distillation for Tailored Language Models 发表:NAACL 2025 机构:德国人工智能研究中心 Abstract 诸如 GPT-4 和 LLaMA-3 等大型语言模型(LLMs)在多个行业展现出变革性的潜力…...
Rollup入门与进阶:为现代Web应用构建超小的打包文件
我们常常面临Webpack复杂配置或是Babel转译后的冗余代码,结果导致最终的包体积居高不下加载速度也变得异常缓慢,而在众多打包工具中Rollup作为一个轻量且高效的选择,正悄然改变着这一切,本文将带你深入了解这个令人惊艳的打包工具…...
博客系统技术需求文档(基于 Flask)
以下内容是AI基于要求生成的技术文档,仅供参考~ 🧱 一、系统架构设计概览 层级 内容 前端层 HTML Jinja2 模板引擎,集成 Markdown 编辑器、代码高亮 后端层 Flask 框架,RESTful 风格,Jinja2 渲染 数据库 SQLi…...
快速排序、归并排序、计数排序
文章目录 前言一、归并排序算法逻辑递归实现非递归实现 二、快速排序算法介绍递归实现非递归实现算法的一种优化—三路划分法 四、计数排序算法原理代码实现优劣分析 五、排序算法的性能比较总结 前言 本文介绍这三种非常强大的排序算法,每种算法都有各自的特点、不…...
python语言与地理处理note 2025/05/11
1. 函数定义必须要在调用之前 (1)正确示例: def test():print("what a wonderful world!")test() (2)错误示例: test() def test():print("what a wonderful world!") 会报错&…...