プロジェクトシナリオ:1. アップロードファイルの制限 関数: 1. フロントエンド操作による異常なファイルのアップロードを防ぐ 機能性: 1. ファイルインスタンスを取得する コードは次のとおりです。 //サイズ制限 checkFileSize(file, rules) { 新しい Promise を返します ((resolve, reject) => { ファイルサイズ / 1024 / 1024 > ルール ? 拒否() : 解決() })。それから( () => { 真を返す }, () => { //操作プロンプト return Promise.reject() } ) }, //アップロード形式の制限 checkFileType(file, rules) { 新しい Promise を返します ((resolve, reject) => { ルール && rules.includes(file.type) ? 解決() : 拒否() })。それから( () => { 真を返す }, () => { //操作プロンプト return Promise.reject() } ) }, //アスペクト比(画像) checkImageWH(ファイル、ルール) { const _this = これ 新しい Promise を返します ((resolve, reject) => { //ファイルを読み取る const filereader = new FileReader() filereader.readAsDataURL(ファイル) ファイルリーダー.onload = e => { 定数src = e.target.result 定数イメージ = 新しいイメージ() イメージ.onload = 関数() { //データを分析し、ルールに準拠しているかどうかを判断します。resolve() } image.onerror = 拒否 画像.src = src } })。それから( () => { 真を返す }, () => { //操作プロンプト return Promise.reject() } ) }, //アスペクト比(ビデオ) checkVideoWH(ファイル、ルール) { 新しいPromise(function(resolve,reject)を返す{ var url = URL.createObjectURL(ファイル) var ビデオ = document.createElement('ビデオ') ビデオ.onloadedmetadata = evt => { URL.revokeObjectURL(url) //データを分析し、ルールに準拠しているかどうかを判断します。resolve() } video.src = URL video.load() // メタデータを取得します })。それから( () => { 真を返す }, () => { //操作プロンプト return Promise.reject() } ) } 実際の通話 //ファイルインスタンスを取得する Screen(){ // 権限ルールを取得します const { filesSize, filesFormat, fileLimit} = this // ファイルサイズ、ファイルタイプ、画像/ビデオの幅と高さの制限 // パラメータの判定 const isFileSize = filesSize ? await this.checkFileSize(file, filesSize) : true const isFileType = filesFormat ? this.checkFileType(file, filesFormat) を待ちます: true //画像マテリアルif (fileLimit && fileLimit.type * 1 === 1) { const isImageLimit = fileLimit? this.checkImageWH(file, fileLimit) を待ちます: true //出力結果 return isFileSize && isFileType && isImageLimit } そうでない場合 (fileLimit&& fileLimit.type * 1 === 2) { //ビデオ素材 const isVideoLimit = fileLimit? await this.checkVideoWH(file, fileLimit) : true //出力結果 return isFileSize && isFileType && isVideoLimit } それ以外 { //制限なし //出力結果 return isFileSize && isFileType } } まとめ: 1. インスタンスを取得する JavaScript アップロードファイル制限パラメータの詳細なケースに関するこの記事はこれで終わりです。より関連性の高い js アップロードファイル制限パラメータの内容については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: MySQLサーバーは--read-onlyオプションで実行されているため、このステートメントを実行できません
>>: Ubuntu 20.04 に Xrdp サーバー (リモート デスクトップ) をインストールする方法
目次1.重複排除を設定する2. 重複を削除するには、2 回の for ループを使用します。 3. i...
MySQL には多くのデータベース管理ツールがあります。作業効率の向上に役立つ優れた GUI ツール...
問題は次のとおりです。mysql -uroot -p コマンドを入力しましたが、パスワードを忘れてし...
k3dとは何ですか? k3d は、Docker で K3s クラスターを実行するための小さなプログ...
目次1. 最も単純なサーバー側の例2. バインドシステムコール2.1、inet_bind 2.2、i...
Deepin がルートユーザーとして Google Chrome ブラウザを起動できない問題を解決す...
問題を見つける最近、MySQL コマンドを使用して MySQL サーバーに接続したときに、以下のよう...
JSONObject は単なるデータ構造であり、JSON 形式のデータ構造 ( key-value構...
今日のタスク1. Linuxディストリビューションの選択2.vmwareが仮想マシン(centos)...
MySQL スロー クエリ ログは、問題のあるクエリを追跡するのに非常に役立ちます。現在のプログラム...
主に2つの側面から: 1. ハイライト/改行2. コードのコピーボタンこれら両方には既製のプラグイン...
序文最近、MySQL のインデックスについて読んでいました。結合されたインデックスを見ると、左端の原...
目次1. 特徴2. 例3. オプション4. 基本的な文法5. ライフサイクル6. ルーティング管理 ...
写真を背景にしてリンクを記載します。たとえば、ウェブサイトのロゴ画像などです。例: ポテトのロゴ画像...
この記事では、パズルゲームを実装するためのjsの具体的なコードを参考までに共有します。具体的な内容は...