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

推薦する

CSS でフロートをクリアするための完全ガイド (要約)

1. 親divは疑似クラスafterとzoomを定義します <スタイル タイプ="...

1つの記事でJSONPの原理と応用を理解する

目次JSONPとはJSONP 原則JSONP実装1. Ajaxでクロスドメインリクエストが行われると...

ブラウザの自動フォーム入力によるウェブページのスタイル損失の原因の分析と解決

バックエンドからフロントエンドまで、なんと悲劇なのでしょう。他の人の CSS を自分の jsp We...

Mysql 5.7.19 無料インストール版 (64 ビット) の設定方法に関する詳細なチュートリアル

公式サイトから mysql-5.7.19-winx64 をダウンロードします。これはシステムの 64...

MySQL レプリケーションの詳細な説明と簡単な例

MySQL レプリケーションの詳細な説明と簡単な例マスタースレーブレプリケーション技術は、MySQL...

Windows システムの MySQL が中国語を入力および表示できない問題の解決方法

ステップ 1: メモ帳を使用して、MySQL インストール ディレクトリの「my.ini」ファイルを...

MySQL ステートメントコメントの紹介

MySQL は次の 3 種類のコメントをサポートしています。 1. 行末の「#」文字から。 2. 「...

MySQL マスタースレーブレプリケーションスレッドの状態遷移に関する詳細な理解

序文MySQL マスター スレーブ レプリケーションの基本原理は、スレーブ データベースがマスター ...

CSS でテキストシャドウと要素シャドウ効果を使用する

テキストシャドウの紹介CSSでは、 text-shadowプロパティを使用してテキストの影を設定しま...

MySQLがデータの削除を推奨しない理由

目次序文InnoDB ストレージ アーキテクチャInnodb テーブルスペースインドストレージディス...

Docker ベースの Redis マスタースレーブ クラスタの実装

目次1. Redisイメージを取得する2. 6つのRedisコンテナを作成する3. Redisコンテ...

よく使われるnginxの書き換えルールの詳細な説明

この記事では、Web ページのリンクを美しくするためによく使用される書き換えルールをいくつか紹介しま...

MySQL 学習ノート: データ エンジン

現在のデータベースでサポートされているエンジンを表示します エンジンを表示 +-----------...

jsを使用して写真をアップロードする機能を実現する

フロントエンドで画像をアップロードする原理は、入力 type="file" タグ...

Vueコンポーネントのカスタムイベントの詳細な説明

目次要約する <テンプレート> <div> 要素 <h2>{{メ...