龙空技术网

跟随Mosh入门React

西二旗的哥 66

前言:

眼前兄弟们对“oracleselect分页”大约比较珍视,兄弟们都需要分析一些“oracleselect分页”的相关文章。那么小编在网络上汇集了一些关于“oracleselect分页””的相关内容,希望我们能喜欢,咱们一起来了解一下吧!

概要

这里跟着mosh学习react入门, 整个视频比较基础,涉及到ES6, React类组件、函数式组件、Hook的入门,状态上移。 我看mosh的视频收获最大的就是他的编程思路,比如组件,一般他会先设计组件接口,也就是函数的输入输出,先设计接口参数, 这样划分接口职责。

整个视频内容涉及到分页、排序、过滤,最重要的就是组件一步一步重构。里面还加载一些Clean Code的概念,满满干货。

系统截图组件结构设计

movies-app结构设计

其中用到的知识点

ES6 解构赋值

const { movies, sortColumn, onDelete, onSort, onLike} = this.props;

对象扩展

const sortColumn = {...this.props.sortColumn};

数组扩展

const movies = [...this.state.moves];

lodash

slice take orderBy

使用prop-types类型检查

prop-types包含入参数据类型验证, 设置参数默认值。

受控组件

样式用到了bootstrap 表格组件、分页、listGroup

关键代码片段

import React, { Component } from "react";import { getMovies } from "../services/fakeMoviesService";import { getGenres } from "../services/fakeGenreService";import MoviesTable from "./moviesTable";import Pagination from "./pagination";import { paginate } from "../utils/paginate";import ListGroup from "./listGroup";import _ from "lodash";class Movies extends Component {  state = {    movies: [],    genres: [],    currentPage: 1,    pageSize: 4,    sortColumn: { path: "title", order: "asc" },  };  componentDidMount() {    const genres = [{ name: "All Genres", _id: "" }, ...getGenres()];    this.setState({ movies: getMovies(), genres: genres });  }  handleLike = (movie) => {    const movies = [...this.state.movies];    const index = movies.indexOf(movie);    movies[index] = { ...movies[index] };    movies[index].liked = !movies[index].liked;    this.setState({ movies });  };  handleDelete = (id) => {    const movies = [...this.state.movies].filter((x) => x._id !== id);    this.setState({ movies });  };  handlePageChange = (page) => {    this.setState({ currentPage: page });  };  handleGenreSelect = (genre) => {    this.setState({ selectedGenre: genre, currentPage: 1 });  };  handleSort = (sortColumn) => {    this.setState({ sortColumn });  };  render() {    const {      movies,      genres,      currentPage,      pageSize,      selectedGenre,      sortColumn,    } = this.state;    const filtered =      selectedGenre && selectedGenre._id        ? movies.filter((m) => m.genre._id === selectedGenre._id)        : movies;    const sorted = _.orderBy(filtered, [sortColumn.path], [sortColumn.order]);    const newMovies = paginate(sorted, currentPage, pageSize);    return (      <div className="row">        <div className="col-3">          <ListGroup            items={genres}            selectedItem={selectedGenre}            onItemSelect={this.handleGenreSelect}          />        </div>        <div className="col">          <p>Showing {filtered.length} movies in the database</p>          <MoviesTable            movies={newMovies}            onLike={this.handleLike}            onDelete={this.handleDelete}            onSort={this.handleSort}            sortColumn={this.state.sortColumn}          />          <Pagination            itemsCount={filtered.length}            currentPage={currentPage}            pageSize={pageSize}            onPageChange={this.handlePageChange}          />        </div>      </div>    );  }}export default Movies;
import React, { Component } from "react";import Like from "./like";import TableHeader from "./tableHeader";class MoviesTable extends Component {  render() {    const { movies, onLike, onDelete, sortColumn, onSort } = this.props;    const columns = [      { path: "title", label: "Title" },      { path: "genre.name", label: "Genre" },      { path: "numberInStock", label: "Stock" },      { path: "dailyRentalRate", label: "Rate" },      { key: "like" },      { key: "delete" },    ];    return (      <table className="table">        <TableHeader          columns={columns}          sortColumn={sortColumn}          onSort={onSort}        />        <tbody>          {movies.map((movie) => (            <tr key={movie._id}>              <td>{movie.title}</td>              <td>{movie.genre.name}</td>              <td>{movie.numberInStock}</td>              <td>{movie.dailyRentalRate}</td>              <td>                <Like liked={movie.liked} onClick={() => onLike(movie)} />              </td>              <td>                <button                  onClick={() => onDelete(movie._id)}                  className="btn btn-danger btn-sm"                >                  Delete                </button>              </td>            </tr>          ))}        </tbody>      </table>    );  }}export default MoviesTable;
import React, { Component } from "react";import PropTypes from "prop-types";const Pagination = (props) => {  const { itemsCount, pageSize, currentPage, onPageChange } = props;  const pageCount = Math.ceil(itemsCount / pageSize);  if (pageCount === 1) return null;  const pages = Array.from({ length: pageCount }, (_, i) => i + 1);  return (    <nav>      <ul className="pagination">        {pages.map((page) => (          <li            key={page}            className={page === currentPage ? "page-item active" : "page-item"}          >            <a className="page-link" onClick={() => onPageChange(page)}>              {page}            </a>          </li>        ))}      </ul>    </nav>  );};Pagination.propTypes = {  itemsCount: PropTypes.number.isRequired,  currentPage: PropTypes.number.isRequired,  pageSize: PropTypes.number.isRequired,  onPageChange: PropTypes.func.isRequired,};export default Pagination;
import React, { Component } from "react";/** * 接口三个参数 * columns: array, * onSort: function, * sortColumn: object * **/class TableHeader extends Component {  raiseSort = (path) => {    const sortColumn = { ...this.props.sortColumn };    if (sortColumn.path === path) {      sortColumn.order = sortColumn.order === "asc" ? "desc" : "asc";    } else {      sortColumn.path = path;      sortColumn.order = "asc";    }    this.props.onSort(sortColumn);  };  render() {    return (      <thead>        <tr>          {this.props.columns.map((column) => (            <th              key={column.path || column.key}              onClick={() => this.raiseSort(column.path)}            >              {column.label}            </th>          ))}        </tr>      </thead>    );  }}export default TableHeader;
import React, { Component } from "react";const Like = ({ onClick, liked }) => {  return (    <i      onClick={onClick}      style={{ cursor: "pointer" }}      className={liked ? "fa fa-heart" : "fa fa-heart-o"}      aria-hidden="true"    />  );};export default Like;
import React, { Component } from "react";const ListGroup = ({  items,  textProperty,  valueProperty,  selectedItem,  onItemSelect,}) => {  return (    <ul className="list-group">      {items.map((item) => (        <li          key={item[valueProperty]}          className={            selectedItem === item ? "list-group-item active" : "list-group-item"          }          onClick={() => onItemSelect(item)}        >          {item[textProperty]}        </li>      ))}    </ul>  );};ListGroup.defaultProps = {  textProperty: "name",  valueProperty: "_id",};export default ListGroup;

代码地址:

视频地址:

标签: #oracleselect分页