ファイルが存在するかどうかを判断する JavaScript サンプルコード

ファイルが存在するかどうかを判断する JavaScript サンプルコード

1. ビジネスシナリオ

最近はファイルのアップロードやダウンロードに関する開発をしています。ダウンロードに関しては、以下の方法でダウンロードしています。

   //ダウンロード パスを取得または割り当てます let downUrl;
   //次のメソッドを使用してファイルを直接ダウンロードします。window.location.href = downUrl;

ビジネス上の問題: このファイルが存在しない場合は、ページがジャンプします。

例: 1. ファイルストレージサーバーがダウンしている 2. またはファイルストレージサーバー上のファイルが削除されている

上記のような異常なアクセスはダウンロード機能に問題を引き起こし、ページジャンプはユーザーにとって不親切です。

ここで、ダウンロード時にファイルが存在するかどうかがわかれば、この問題をうまく解決できます。

2. 解決策

2つの解決策を提供する

1. バックエンドソリューション: 一般的に、ファイルは専用のキーを持つファイルストレージサーバーに保存されます。ファイルが存在するかどうかを照会するための別のインターフェイスがあるかどうかを確認します。つまり、ダウンロードする前に、ファイルの一意のキーに基づいてファイルが存在するかどうかを照会します。存在する場合は、ダウンロードステートメントを実行します。存在しない場合は、ユーザーに対応するプロンプトを表示します。

             もし(){
             //ファイルが存在する場合はダウンロードします }else{
             //それ以外の場合は対応するプロンプトを表示します}

2. フロントエンドソリューション: フロントエンド方式は、ファイルストリームが存在するかどうかを判断します。

実用的な参考として、Vueでのメソッド記述方法を紹介します。

            /**
             * サービスファイルが存在するかどうかを判断します* @param filepath ファイルアドレス* @param filename
             * @returns {ブール値}  
             */
         isExistFile(ファイルパス、ファイル名){
              if(ファイルパス == null || ファイル名 == null || ファイルパス === "" || ファイル名 ===""){
                偽を返す
               }
              var xmlhttp;
              if (window.XMLHttpRequest){
                xmlhttp = 新しい XMLHttpRequest();
              }それ以外{
                xmlhttp = 新しい ActiveXObject("Microsoft.XMLHTTP");
             }
              xmlhttp.open("GET",ファイルパス,false);
              xmlhttp.send();
              xmlhttp.readyState === 4の場合{
              if(xmlhttp.status === 200) return true; //URL が存在する else if(xmlhttp.status === 404) return false; //URL が存在しない else return false;//その他のステータス}
       }

後続のロジックは自分で補足できます。上記のように、ファイル ストリームが存在するかどうかをテストできます。存在する場合はダウンロードします。存在しない場合は、対応するプロンプトを表示します。これにより、ファイル パスが存在しない場合に空白ページにジャンプする問題が解決されます。

補足: 「ストリーム」は抽象的な概念であり、入出力デバイスを抽象的に理解したものです。Java では、データの入出力操作は「ストリーム」方式で実行されます。

要約:

ビジネス上の問題に遭遇したとき、フロントエンドとバックエンドの両方の観点から考え、学び、共有して新しい知識を獲得し、さらなる進歩を期待することができます...

これで、ファイルが存在するかどうかを判定する JavaScript に関するこの記事は終了です。ファイルが存在するかどうかを判定する JavaScript に関する関連記事については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • JavaScript を使用してファイルが存在するかどうかを判断する
  • JavaScriptはファイルが存在するかどうかを判定するインスタンスコード
  • Javascript はファイルが存在するかどうかを判断します (クライアント/サーバー)
  • JavaScript で fso を使用してファイルが存在するかどうかを判断するコード

<<:  Nginxを再コンパイルしてモジュールを追加する方法

>>:  MySQL 5.7.21 解凍版のインストールと設定方法のグラフィックチュートリアル

推薦する

HTML 内の CSS および JS リンクのバージョン番号 (キャッシュを更新)

背景検索エンジンで「.htaccess キャッシュ」というキーワードを検索すると、ウェブサイトのファ...

Linux での MySQL 8.0 インストール チュートリアル

この記事では、LinuxでMySQL 8.0をインストールする方法を紹介します。具体的な内容は次のと...

JavaScript BOMの構成と一般的なイベントの詳細な説明

目次1. 部品2. BOMの構成2. ウィンドウオブジェクトの共通イベント1. ウィンドウ読み込みイ...

画像ボタンをフォームのリセットボタンとして使用する方法

フォームを作成するときに、送信ボタンとリセットボタンを配置することがよくあります。ページの外観を考慮...

Vue カプセル化に基づくプルダウン更新およびプルアップ読み込みコンポーネント

VueとネイティブJavaScriptカプセル化に基づいて、プルダウンリフレッシュとプルアップロード...

JS での filter() 配列フィルターの使用

目次1. はじめに2. 方法の紹介3. 使用例要約する1. はじめに配列フィルターは、フロントエンド...

Docker の Windows ストレージ パス設定操作

Windows 10 に Docker をインストールする場合、コンテナタイプを Linux コンテ...

CSS3 背景コントロールプロパティと色遷移を使用してグラデーション効果を実現します。

CSS3 背景画像関連互換性: IE9+背景クリップ 背景画像描画領域background-cli...

NavicatがMySQLに接続すると、10060、1045エラーとmy.iniの場所が報告されます。

Navicat は、データベースに接続するときにエラー 10060 および 1045 を報告します...

MySQL 権限昇格のさまざまな形態の概要

目次1. Webshel​​lを書く出力ファイルにシェルを書き込むログファイル書き込みシェル2. U...

MySQLはトリガーを使用してデータベース内のテーブルの行制限を解決します。詳細な説明と例

MySQLはトリガーを使用してデータベース内のテーブルの行制限を解決します。詳細な説明と例最近のプロ...

Spark と Scala を使用して Apache アクセス ログを分析する方法

インストールまず、Java と Scala をインストールし、次に Spark をダウンロードしてイ...

MySQL 5.7 で my.ini ファイルが見つからない場合の解決策

my.ini とは何ですか? my.ini は、MySQL データベースで使用される設定ファイルです...

MYSQL8.0.13 無料インストール版 設定チュートリアル例 詳細説明

1. ダウンロード、例として8.0を取り上げますダウンロードアドレス: https://dev.my...

Docker 用ビジュアル UI 管理ツール Portainer のインストールと使用方法の分析

Portainer は、ステータス表示パネル、アプリケーション テンプレートの迅速な展開、コンテナ ...