Vue-pdfはPDFファイルのオンラインプレビューを実装します

Vue-pdfはPDFファイルのオンラインプレビューを実装します

序文

ほとんどのプロジェクトでは、PDF ファイルのオンライン プレビューに遭遇するでしょう。このプロジェクトは、要素 ui を使用し、vue-pdf を使用して実装されています。

依存関係をインストールする

npm インストール --save vue-pdf

関連パラメータ

パラメータの紹介:

  • url: PDF ファイルのパス。ローカル パスまたはオンライン パスにすることができます。
  • page: 現在表示されているページ番号。例: 最初のページ page=1
  • rotate: 回転角度。たとえば、0 は回転なし、+90 および -90 は水平回転を意味します。
  • progress: 現在のページの読み込みの進行状況。範囲は 0 ~ 1 です。1 の場合、現在のページが完全に読み込まれたことを意味します。
  • page-loaded: ページの読み込みが成功した場合のコールバック関数。ほとんど使用されません。
  • num-pages : 総ページ数
  • error: 読み込みエラーのコールバック
  • リンクがクリックされると、スタンドアロン PDF 内のリンクがトリガーされます。
  • print これは印刷機能です。 注意: Google Chrome では、フォントに関連する文字化けした文字が表示されます。

成し遂げる

<テンプレート>
    <div>
        <el-行>
            <el-button @click="onPreview" size="small">プレビュー</el-button>
        </el-row>
        <el-dialog title="契約書添付ファイルのプレビュー" :visible.sync="viewVisible" center width="60%" @close='closePreview'>
            <el-row :gutter="20">
                <span>合計 {{pageCount}} ページ、現在のページ {{pdfPage}}</span>
                <el-button type="text" size="mini" @click.stop="previousPage">前のページ</el-button>
                <el-button type="text" size="mini" @click.stop="nextPage">次のページ</el-button>
            </el-row>
            <div>
                <pdf :src="src" :page="pdfPage" @num-pages="pageCount = $event" @page-loaded="pdfPage = $event" style="display: inline-block; width: 100%"></pdf>
            </div>
        </el-ダイアログ>
    </div>
</テンプレート>
<スクリプト>
'vue-pdf' から pdf をインポートします
'@/store/' からストアをインポートします
エクスポートデフォルト{
    コンポーネント:{
        pdf
    },
    データ(){
        戻る {
            viewVisible: false、
            ソース: null、
            pdfページ: 1,
            ページ数: 0,
            トークン: store.getters.access_token、
        }
    },
    方法:{
        プレビュー(){
            this.src = pdf.createLoadingTask({
                URL: 'http://localhost:8082/file/demo.pdf',
                httpHeaders: {Authorization:'Bearer'+ this.token}
            });
            this.src.promise.then(pdf => {
                this.viewVisible = true;
            });
        },
        プレビューを閉じる(){
            this.pdfページ = 1;
        },
        前のページ(){
            p = this.pdfページとする
            p = p > 1 ? p-1 : this.pageCount
            this.pdfページ = p
        },
        次のページ(){
            p = this.pdfページとする
            p = p < this.pageCount ? p+1 : 1
            this.pdfページ = p
        }
    }
}
</スクリプト>

効果

注記

1. URL

urlはファイルアドレスパスです

this.src = pdf.createLoadingTask({
    URL: 'http://localhost:8082/file/demo.pdf',
});

2. リクエストヘッダーを設定する

httpHeadersを通じてトークンなどのパラメータを設定できます

httpHeaders: {Authorization:'Bearer'+ this.token}

3. 出典

これはもっと重要です。インターネット上の多くの投稿はこのようなものです。

this.src.then(pdf => {
    this.viewVisible = true;
})

TypeError を報告します: this.src.then は関数ではありません

TypeError: this.src.then は関数ではありません
    VueComponent.onPreview (index.vue?6ced:241) で
    クリック時 (index.vue?aaff:261)
    呼び出し時にエラー処理 (vue.runtime.esm.js?2b0e:1854)
    VueComponent.invoker (vue.runtime.esm.js?2b0e:2179) で
    呼び出し時にエラー処理 (vue.runtime.esm.js?2b0e:1854)
    VueComponent.Vue.$emit (vue.runtime.esm.js?2b0e:3888) で
    VueComponent.handleClick (element-ui.common.js?5c96:9413) で
    呼び出し時にエラー処理 (vue.runtime.esm.js?2b0e:1854)
    HTMLButtonElement.invoker (vue.runtime.esm.js?2b0e:2179) で
    HTMLButtonElement.original._wrapper (vue.runtime.esm.js?2b0e:6917) で

正解はこれです

this.src.promise.then(pdf => {
    this.viewVisible = true;
});

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • Vue は PDF ファイルのオンライン プレビューとダウンロードを実装します (pdf.js)
  • Vue は PDF ドキュメントのオンライン プレビュー機能を実装しました
  • Vue プラグイン開発: pdf.js を使用してモバイル フォンで PDF ドキュメントのオンライン プレビューを実現する方法
  • Office ファイルのオンライン プレビュー用の Vue サンプル コード
  • Vue は PDF ファイルのオンライン プレビューを実装します (pdf.js/iframe/embed を使用)
  • vue vue-pdf を使用して PDF オンライン プレビューを実装するためのサンプル コード
  • vue-pdf はオンラインファイルプレビューを実現します
  • Vue プロジェクトでよく使用される 3 つのファイル タイプ (pdf/word/excel テーブル) のオンライン プレビュー

<<:  Windows 8 での MySQL Community Server 5.6 のインストールと設定のチュートリアル

>>:  Linux C バックグラウンドサービスプログラムの単一プロセス制御の実装

推薦する

Dockerデータストレージのバインドマウントの詳細な説明

この記事を読む前に、Volumes について予備知識を身に付けておいてください。詳細については、こち...

JavaScriptプロトタイプチェーンを理解する

目次1. プロトタイプとプロトタイプチェーンの平等関係を理解する2: プロトタイプとプロトタイプ チ...

負のz-indexを持つ要素がクリックできない問題の解決策

最近、ポップアップ広告に取り組んでいました。デフォルト ページには z-index が設定されていな...

Vue+element ui はアンカーの配置を実現します

この記事では、アンカー配置を実現するためのVue +要素UIの具体的なコードを例として紹介します。具...

MySQL 検査スクリプト (必読)

以下のように表示されます。 #!/usr/bin/env python3.5 psutilをインポー...

収集する価値のある Linux ドキュメント編集コマンド 27 個

Linux col コマンドLinux の col コマンドは制御文字をフィルタリングするために使用...

Centos 用の rpm パッケージのカスタマイズと yum リポジトリの構築に関するチュートリアル

1 yumでソフトウェアをインストールしたときにダウンロードしたrpmパッケージを保存しますyum ...

JSは検証コードのランダム生成を実装します

この記事の例では、検証コードのランダム生成を実現するためのJSの具体的なコードを参考までに共有してい...

MySql のインデックス、ロック、トランザクションの知識ポイントのまとめ

この記事では、MySql のインデックス、ロック、トランザクションに関する知識のポイントをまとめてい...

MySQLの文字列インターセプト関連関数の概要

この記事では、MySQL の文字列インターセプト関連の機能を紹介します。具体的な内容は以下のとおりで...

Tomcatはスレッドプールを使用してリモート同時リクエストを処理します。

Tomcatが同時リクエストを処理する方法を理解することで、スレッドプール、ロック、キュー、および...

Nginx のインストールと設定ルールの詳細な紹介

目次1. nginxのインストールと操作(Mac OS環境) 2. nginxルールの設定3. コマ...

mysql 8.0.18 mgr のインストールと切り替え機能

1. システムインストールパッケージ yum -y インストール make gcc-c++ cmak...

雨滴効果を実現する JavaScript キャンバス

この記事の例では、雨滴効果を実現するためのキャンバスの具体的なコードを参考までに共有しています。具体...

MySQLの手順を完全に削除する

目次1. まずMySQLサーバーを停止する2. MySQLサーバーをアンインストールする3. MyS...