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 バックグラウンドサービスプログラムの単一プロセス制御の実装

推薦する

202 無料の高品質 XHTML テンプレート (1)

ここで 123WORDPRESS.COM はこれらのテンプレートの最初の部分を紹介します。各テンプレ...

Docker に Kong ゲートウェイをインストールする方法の例

1. Dockerネットワークを作成する docker ネットワーク作成 kong-net 2. デ...

CentOS システムの rpm インストールと Nginx の設定

目次CentOS rpm のインストールと Nginx の設定導入rpm パッケージのインストールサ...

Docker のホスト間コンテナ通信オーバーレイ実装プロセスの詳細な説明

サーバーも 2 つあります。準備:コンテナのホスト名を設定する consul: kv タイプのストレ...

JavaScriptはキャンバスを使用して座標と線を描画します

この記事では、JavaScriptでキャンバスを使用して座標と線を描く具体的なコードを参考までに紹介...

WeChatアプレットはシンプルなサイコロゲームを実装します

この記事では、サイコロゲームを実装するためのWeChatアプレットの具体的なコードを参考までに共有し...

Vueはミックスインを使用してコンポーネントを最適化します

目次ミックスインの実装フック関数のマージプロジェクト実践伸ばす要約するVue は mixins AP...

HTML ウェブページ作成のための 8 つの強力なテクニック

<br />作業を簡単に完了できる Web ページ作成ツールは数多くありますが、HTML...

JavaScriptの動作原理を理解しましょう

目次ブラウザカーネルJavaScript エンジンV8エンジンJavaScript がどのように実行...

Vue Element フロントエンドアプリケーション開発: Vuex での API ストアビューの使用

目次概要1. フロントエンドとバックエンドの分離とWeb APIの優先ルート設計2. Axiosネッ...

ハイパーリンクアイコンの仕様: 記事の読みやすさを向上

1. ハイパーリンクアイコンの仕様とは?<br />ハイパーリンクアイコンの仕様は、「C...

Linux で ss コマンドと zabbix を組み合わせてソケットを監視する方法の詳細な説明

目次序文1. ssコマンド2. Zabbix監視マシンの全体的なソケットステータス2.1. スクリプ...

CentOS7でPHPスケジュールタスクを実行する方法

序文この記事は主に CentOS7 で PHP スケジュールタスクを実行することに関する関連コンテン...

水平スクロールバーを実装する2つの方法の例

序文:プロジェクトの開発中に、1 行にナビゲーション バーが多すぎる場合に水平スクロール バーを実装...

MySQL 5.7.15 のインストールと設定方法のグラフィック チュートリアル (Windows)

MySQL をインストールする必要があるため、インストール手順を以下のように記録します。 自分なり...