react-pdf-js 的使用

A React component to wrap PDF.js

Install

yarn add react-pdf-jsornpm install react-pdf-js

Demo

http://mikecousins.github.io/react-pdf-js/
在此 demo 中可实现翻页的功能
实现的代码如下 :

import React from 'react';
import PDF from 'react-pdf-js';

class MyPdfViewer extends React.Component {
  state = {};

  onDocumentComplete = (pages) => {
    this.setState({ page: 1, pages });
  }

  handlePrevious = () => {
    this.setState({ page: this.state.page - 1 });
  }

  handleNext = () => {
    this.setState({ page: this.state.page + 1 });
  }

  renderPagination = (page, pages) => {
    let previousButton = <li className="previous" onClick={this.handlePrevious}><a href="#"><i className="fa fa-arrow-left"></i> Previous</a></li>;
    if (page === 1) {
      previousButton = <li className="previous disabled"><a href="#"><i className="fa fa-arrow-left"></i> Previous</a></li>;
    }
    let nextButton = <li className="next" onClick={this.handleNext}><a href="#">Next <i className="fa fa-arrow-right"></i></a></li>;
    if (page === pages) {
      nextButton = <li className="next disabled"><a href="#">Next <i className="fa fa-arrow-right"></i></a></li>;
    }
    return (
      <nav>
        <ul className="pager">
          {previousButton}
          {nextButton}
        </ul>
      </nav>
      );
  }

  render() {
    let pagination = null;
    if (this.state.pages) {
      pagination = this.renderPagination(this.state.page, this.state.pages);
    }
    return (
      <div>
        <PDF
          file="test.pdf"
          onDocumentComplete={this.onDocumentComplete}
          page={this.state.page}
        />
        {pagination}
      </div>
    )
  }
}

export default MyPdfViewer;

example

github react-pdf-js

import React from 'react';
import PDF from 'react-pdf-js';

class Demo extends React.Component {
      render() {
    return (
      <div>
        <PDF
          file="http://.../xxx.pdf"
        />
      </div>
    )
  }
}

export default Demo;

note

使用 react-pdf-js 实现pdf 的展示,使用的 canvas 不随可视窗口的大小变化而变化,可使用 width 设置宽度。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1、通过CocoaPods安装项目名称项目信息 AFNetworking网络请求组件 FMDB本地数据库组件 SD...
    阳明AGI阅读 16,008评论 3 119
  • 今日体验:提前为了客户考虑,首先解决客户问题,更好的服务为客户建立维修项目,更好的服务
    京心达奥迪组王刚阅读 123评论 0 0
  • |一周练习回顾 不知不觉,刻意训练营又推进了一周,这周主要练习的是背诵。坦率地讲,本周练习的有些心不在焉。客观原因...
    老王大胡子阅读 157评论 0 0
  • 其实不应感叹时光的流逝,时间本应被重新定义,因为日月变换,因为孩子的成长所以觉得日子在向前流逝,只有集中了精力方可...
    易元熙阅读 103评论 0 0
  • 这是个特别的数字,里面有彩色的青葱岁月,宛如生命里的阳光,它穿透了整个黑暗的世界,划过一群流星雨,...
    摆渡娇娘阅读 663评论 0 0