Convert Figma logo to code with AI

kdchang logoreactjs101

從零開始學 ReactJS(ReactJS 101)是一本希望讓初學者一看就懂的 React 中文入門教學書,由淺入深學習 ReactJS 生態系 (Flux, Redux, React Router, ImmutableJS, React Native, Relay/GraphQL etc.)。

4,319
1,215
4,319
57

Top Related Projects

45,627

Cheatsheets for experienced React developers getting started with TypeScript

A collection of awesome things regarding React ecosystem

Curated List of React Components & Libraries.

Code from the React tutorial.

🔥 A highly scalable, offline-first foundation with the best developer experience and a focus on performance and best practices.

Quick Overview

ReactJS 101 is a comprehensive guide to learning React.js and its ecosystem. It covers fundamental concepts, advanced topics, and best practices for building modern web applications using React. The repository serves as an educational resource for developers looking to master React development.

Pros

  • Extensive coverage of React concepts, from basics to advanced topics
  • Includes practical examples and projects to reinforce learning
  • Regularly updated to reflect the latest React features and best practices
  • Available in both English and Chinese, making it accessible to a wider audience

Cons

  • May be overwhelming for absolute beginners due to the breadth of content
  • Some sections might become outdated as React and its ecosystem evolve rapidly
  • Lacks interactive coding exercises or quizzes for self-assessment
  • Limited coverage of React Native and mobile development

Getting Started

To get started with ReactJS 101:

  1. Clone the repository:

    git clone https://github.com/kdchang/reactjs101.git
    
  2. Navigate to the project directory:

    cd reactjs101
    
  3. Open the README.md file to access the table of contents and start learning:

    open README.md
    
  4. Follow the chapters in order, starting with the "React Ecosystem" section to build a strong foundation before moving on to more advanced topics.

Competitor Comparisons

45,627

Cheatsheets for experienced React developers getting started with TypeScript

Pros of react

  • Focuses specifically on TypeScript with React, providing in-depth TypeScript-specific guidance
  • Regularly updated with contributions from the community, ensuring up-to-date information
  • Offers cheatsheets for various React-TypeScript scenarios, making it a quick reference guide

Cons of react

  • Less comprehensive for React beginners, assuming prior React knowledge
  • Lacks detailed explanations of React concepts, focusing primarily on TypeScript integration
  • May be overwhelming for those new to TypeScript due to its advanced content

Code Comparison

reactjs101:

class MyComponent extends React.Component {
  render() {
    return <div>Hello, World!</div>;
  }
}

react:

const MyComponent: React.FC = () => {
  return <div>Hello, World!</div>;
};

The reactjs101 example uses a class component with JavaScript, while the react example demonstrates a functional component with TypeScript typing.

Summary

reactjs101 is better suited for React beginners, offering a comprehensive introduction to React concepts in JavaScript. react, on the other hand, is ideal for developers already familiar with React who want to leverage TypeScript in their projects. It provides specific TypeScript-React integration guidance and serves as a quick reference for various scenarios.

A collection of awesome things regarding React ecosystem

Pros of awesome-react

  • Comprehensive collection of React resources, tools, and libraries
  • Regularly updated with new content and community contributions
  • Well-organized structure with clear categories for easy navigation

Cons of awesome-react

  • Lacks in-depth tutorials or step-by-step learning materials
  • May be overwhelming for beginners due to the sheer volume of information
  • Does not provide code examples or practical implementations

Code comparison

reactjs101:

import React from 'react';

const HelloWorld = () => (
  <div>Hello, World!</div>
);

export default HelloWorld;

awesome-react:

No code examples are provided in the awesome-react repository, as it primarily serves as a curated list of resources rather than a tutorial or code repository.

Summary

reactjs101 is a comprehensive React.js tutorial aimed at beginners, providing step-by-step guidance and code examples. It offers a structured learning path but may not cover the latest React features or advanced topics.

awesome-react, on the other hand, is an extensive collection of React-related resources, tools, and libraries. It serves as a valuable reference for developers of all levels but doesn't provide direct learning materials or code examples.

Choose reactjs101 for a guided learning experience, or awesome-react for a comprehensive list of React resources and tools to explore.

Curated List of React Components & Libraries.

Pros of awesome-react-components

  • Extensive collection of React components, libraries, and tools
  • Regularly updated with new components and resources
  • Well-organized into categories for easy navigation

Cons of awesome-react-components

  • Lacks in-depth tutorials or explanations for using components
  • May overwhelm beginners with the sheer number of options
  • No step-by-step guide for building React applications

Code Comparison

reactjs101 provides code examples for learning React concepts:

class Counter extends React.Component {
  constructor(props) {
    super(props);
    this.state = { count: 0 };
  }
  render() {
    return <div>Count: {this.state.count}</div>;
  }
}

awesome-react-components doesn't typically include code examples, but rather links to component repositories:

- [react-datepicker](https://github.com/Hacker0x01/react-datepicker) - A simple and reusable datepicker component for React.
- [react-big-calendar](https://github.com/intljusticemission/react-big-calendar) - Calendar component.
- [react-dnd](https://github.com/react-dnd/react-dnd) - Drag and Drop for React.

Summary

reactjs101 is a comprehensive tutorial for learning React, while awesome-react-components is a curated list of React components and libraries. reactjs101 is better for beginners looking to learn React from scratch, while awesome-react-components is more suitable for developers seeking specific components for their projects.

Code from the React tutorial.

Pros of react-tutorial

  • Official React tutorial, ensuring up-to-date and accurate information
  • Focuses on a single, practical project (tic-tac-toe game)
  • Includes an interactive coding environment for hands-on learning

Cons of react-tutorial

  • Limited in scope, covering only basic React concepts
  • May not provide in-depth explanations for more advanced topics
  • Less comprehensive than reactjs101, which covers a wider range of React-related subjects

Code Comparison

reactjs101:

import React from 'react';

const HelloWorld = () => (
  <div>Hello, World!</div>
);

export default HelloWorld;

react-tutorial:

function Square(props) {
  return (
    <button className="square" onClick={props.onClick}>
      {props.value}
    </button>
  );
}

The reactjs101 example demonstrates a simple functional component, while the react-tutorial code shows a more interactive component with props and event handling. This reflects the different approaches of the two repositories, with reactjs101 focusing on broader concepts and react-tutorial emphasizing practical application in a specific project context.

🔥 A highly scalable, offline-first foundation with the best developer experience and a focus on performance and best practices.

Pros of react-boilerplate

  • More comprehensive and production-ready setup with advanced features
  • Includes Redux, Redux-Saga, and Reselect for state management
  • Offers a scalable architecture for large applications

Cons of react-boilerplate

  • Steeper learning curve due to its complexity
  • May be overkill for smaller projects or beginners
  • Requires more setup and configuration

Code Comparison

reactjs101:

import React from 'react';
import ReactDOM from 'react-dom';

ReactDOM.render(
  <h1>Hello, World!</h1>,
  document.getElementById('app')
);

react-boilerplate:

import React from 'react';
import { render } from 'react-dom';
import { Provider } from 'react-redux';
import { ConnectedRouter } from 'connected-react-router';
import history from 'utils/history';
import App from 'containers/App';

const MOUNT_NODE = document.getElementById('app');

render(
  <Provider store={store}>
    <ConnectedRouter history={history}>
      <App />
    </ConnectedRouter>
  </Provider>,
  MOUNT_NODE
);

Summary

reactjs101 is more suitable for beginners and smaller projects, offering a simpler setup and easier learning curve. react-boilerplate provides a more robust foundation for large-scale applications with advanced features and scalable architecture, but requires more expertise to utilize effectively.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

從零開始學 ReactJS(ReactJS 101)

一本給初學者的 React 中文入門教學書,由淺入深學習 ReactJS 生態系 (Flux, Redux, React Router, ImmutableJS, React Native, Relay/GraphQL etc.),打造跨平台應用程式。

從零開始學 ReactJS(ReactJS 101)

相關連結(Links)

  1. 從零開始學 ReactJS(ReactJS 101)粉絲頁

  2. 繁體中文範例程式碼和書籍內容連載位置

  3. 勘誤、許願、建議或提問

翻譯版本(Translate)

  1. 简体中文版本 by @carlleton
  2. 前端圈简体中文版本 by @blueflylin 特別感謝前端圈小夥伴!

若需翻譯成其他語言版本,請先 fork 一份 repo 到自己的 GitHub 並另外開新的 branch。最後將翻譯版本連結更新在 master 分支中 README.md 的 相關連結(Links) 後發送 Pull Request,謝謝您。

目錄(Table of Contents)

先備知識(Prior Knowledge)

本書針對已具備基本 HTML、CSS 和 JavaScript 和 DOM 操作知識的讀者設計,但若讀者對上述的技術仍不熟悉的話,建議可以先行參考:MDN、Codecademy、W3C School、JavaScript核心 或是參考筆者 之前的教學講義 進行學習。另外,本書全書範例都將以 ES6+ 撰寫,若需參考 ES5 用法,請參考附錄一的 React ES5、ES6+ 常見用法對照表。

關於作者(Author)

@kdchang 文藝型開發者,夢想是做出人們想用的產品和辦一所心目中理想的學校,目前專注在 Mobile 和 IoT 應用開發。A Starter & Maker. JavaScript, Python & Arduino/Android lover.:)

版權許可(License)

本書採用創用CC授權4.0 "姓名標示─非商業性─相同方式分享(BY-NC-SA)" 授權。

從零開始學 ReactJS(ReactJS 101)

本授權條款允許使用者重製、散布、傳輸以及修改著作,但不得為商業目的之使用。若使用者修改該著作時,僅得依本授權條款或與本授權條款類似者來散布該衍生作品。使用時必須按照著作人指定的方式表彰其姓名。

詳細資訊請參考 CC BY-NC-SA 4.0。

關鍵字(Keywords)

React, React Native, React Router, Flux, Redux, Node, Express, ImmutableJS, NPM, Babel, Browserify, Webpack, Gulp, Grunt, Pure Functions, PropTypes, Stateless Functional Components, Presentational Components, ES6, ES5, JSX, Jest, Unit Test, Component, Relay, GraphQL, Universal/Isomorphic, React Tutorial React教程, React教學, 學React, React Tutorial, Tutorial, Ecosystem, Front-End