亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

目次
ファイルドラッグアンドドロップの場所としてFileDrag要素が使用されます。この要素はCSSに隠されていますが、ドラッグアンドドロップがサポートされている場合、javaScriptで有効になります:
ホームページ ウェブフロントエンド jsチュートリアル HTML5ファイルのドラッグアンドドロップの使用方法

HTML5ファイルのドラッグアンドドロップの使用方法

Feb 25, 2025 am 09:48 AM

html5の詳細(xì)な説明ドラッグアンドドロップファイルアップロード:クライアントファイル処理と非同期サーバーのアップロード

How to Use HTML5 File Drag and Drop

コアポイント

  • HTML5は、Webページ要素にファイルのドラッグとドロップをサポートし、JavaScriptのドラッグアンドドロップファイルを分析し、クライアントにファイルをロードおよび解析し、XMLHTTPREQUEST2を使用してファイルをサーバーにアップロードし、アップロード中にグラフィカルな進(jìn)行狀況を表示します。
  • 最新のHTML5テクノロジーを使用しているため、ブラウザのサポートは不均一になる場合があります。 FirefoxおよびChromeの現(xiàn)在のバージョンはすべての機(jī)能をサポートしていますが、Opera、IE、およびSafariサポートは限られているか、まったくサポートされていません。
  • ファイルのドラッグアンドドロップを有効にするには、JavaScriptイベントをファイル入力要素と#FileDRAG要素に添付する必要があります。 #FileDRAG要素も表示され、フォーム送信ボタンを非表示にする必要があります。
  • W3CファイルAPIは、FileList、File、およびFileReaderを含むファイル操作、および選択したファイル、個(gè)々のファイルを表し、クライアントのファイルデータをそれぞれ読み取り、そのインターフェイスを使用するオブジェクトを提供します。
ブラウザにデスクトップファイルをドラッグアンドドロップすることは、Webアプリケーション統(tǒng)合の究極の目標(biāo)の1つです。これは、次の方法を紹介します。 4. XmlhttpRequest2を使用して、ファイルを上映します。

ブラウザ互換性チャレンジ

開始前に、このチュートリアルには最新のHTML5テクノロジーの一部が含まれるため、サポートは不均一になると予想されます。コードは現(xiàn)在動作しますが、APIが変更され、ブラウザが進(jìn)化し続けています。 -FirefoxとChromeの最新バージョンは、すべての機(jī)能をサポートし、完全に実行します。 -OperaはJavaScriptでファイルを解析できますが、ファイルのドラッグアンドドロップとXMLHTTPREQUEST2アップロードを?qū)g裝しません。 -IEおよびSafariのデスクトップバージョンは、APIをサポートしていません。 -Appleは、iPhoneおよびiPadバージョンのSafariにHTMLファイルアップロードフォームを無効にしています。

誰かが理由を知っていますか?

最後に、私のコードが基本概念を示していることに注意してください。エラーチェックは非常に少ないため、生産システムを調(diào)整する必要があります。

htmlおよびcss

これは、ファイル入力タイプの標(biāo)準(zhǔn)フォームです。唯一のHTML5機(jī)能は「複數(shù)の」プロパティで、ユーザーは任意の數(shù)のファイルを選択できるようにします。 PHPを?qū)g行しているサーバーにファイルをアップロードしますが、コードはどのテクノロジーを使用してもほぼ同じです。 Hidden Max_file_size値は300,000バイトを指定します-PHPはこの値を使用しますが、クライアントにもチェックして、大きなファイルのアップロードを防ぎます。

<fieldset><legend>HTML文件上傳</legend>
<div>
  <input type="file" id="fileselect" name="fileselect[]" multiple="multiple">
  <label for="fileselect">選擇要上傳的文件:</label>
  <div id="filedrag">或?qū)⑽募戏诺酱颂?lt;/div>
</div>
<input type="submit" value="上傳文件" id="submitbutton">
</fieldset>
<div id="messages">狀態(tài)信息</div>

ファイルドラッグアンドドロップの場所としてFileDrag要素が使用されます。この要素はCSSに隠されていますが、ドラッグアンドドロップがサポートされている場合、javaScriptで有効になります:

#filedrag {
    display: none;
    font-weight: bold;
    text-align: center;
    padding: 1em 0;
    margin: 1em 0;
    color: #555;
    border: 2px dashed #555;
    border-radius: 7px;
    cursor: default;
}

#filedrag.hover {
    color: #f00;
    border-color: #f00;
    border-style: solid;
    box-shadow: inset 0 3px 4px #888;
}
また、ユーザーがファイルを要素にドラッグするとスタイルを変更する.hoverクラスも定義します。ブラウザは適用されません。この場合はホバースタイルですが、イベントが発生した場合、JavaScriptを使用してクラスを追加できます。

ファイルapi

w3cファイルAPIはいくつかのオブジェクトを提供します。以下を使用します。-FileList:選択したファイルを表す配列。 - ファイル:単一のファイルを表します。 -FileReader:クライアントのファイルデータを読み取り、JavaScriptで使用できるインターフェイス。

JavaScriptイベント< JavaScriptの使用を開始する時(shí)が來ました。 JavaScriptライブラリを使用していないため、タイピング指を保存するために、IDおよび出力ステータスメッセージで要素を返すためにいくつかのヘルパー関數(shù)を作成します。

ファイルAPIが利用可能かどうかを確認(rèn)し、init()関數(shù)を呼び出します:

// 通過ID獲取元素
function $id(id) {
    return document.getElementById(id);
}

// 輸出信息
function Output(msg) {
    var m = $id("messages");
    m.innerHTML = msg + m.innerHTML;
}
init()関數(shù):1。ファイル入力要素の「変更」イベントリスナーを設(shè)定します。 2. #filedrag要素を表示します。 3.「Dragover」および「Dragleave」イベントリスナーを設(shè)定して、#FileDrag要素のスタイルを変更します。 4. #FileDrag要素の「ドロップ」イベントリスナーを設(shè)定します。 5。フォーム送信ボタンを非表示 - 選択したファイルを分析してアップロードするため、必要ありません。

ファイルのドラッグアンドドロップをサポートするときに、ファイル入力要素を非表示にすることができます。個(gè)人的には、ドラッグアンドドロップがユーザビリティの問題をもたらすため、両方のオプションを提供することを好みます。 xmlhttprequest.uploadメソッドチェックは、オペラの問題を防ぐことができます。ブラウザはファイル、FilleRist、およびFileReaderをサポートしていますが、ドラッグアンドドロップイベントまたはXMLHTTPREQUEST2をサポートしていません。そのため、ファイル情報(bào)を表示できますが、#FiledRag要素を表示したり、送信ボタンを削除したりしたくありません。
// 調(diào)用初始化文件
if (window.File && window.FileList && window.FileReader) {
    Init();
}

// 初始化
function Init() {

    var fileselect = $id("fileselect"),
        filedrag = $id("filedrag"),
        submitbutton = $id("submitbutton");

    // 文件選擇
    fileselect.addEventListener("change", FileSelectHandler, false);

    // XHR2是否可用?
    var xhr = new XMLHttpRequest();
    if (xhr.upload) {

        // 文件拖放
        filedrag.addEventListener("dragover", FileDragHover, false);
        filedrag.addEventListener("dragleave", FileDragHover, false);
        filedrag.addEventListener("drop", FileSelectHandler, false);
        filedrag.style.display = "block";

        // 移除提交按鈕
        submitbutton.style.display = "none";
    }

}

ファイルドラッグアンドドロップスタイルの変更

一部の人々は、Webブラウザーでファイルのドラッグアンドドロップを経験しています。実際、経験豊富なWebユーザーはこれが不可能だと思うかもしれません。そこで、「ここにファイルをドラッグアンドドロップする」と宣言する要素を使用しました。また、スタイルを変更して、ファイルを#FileDRAGの場所にドラッグアンドドロップするタイミングを示したいと思います。

ドラッグアンドドロップまたは選択したファイルを分析します

// 文件拖放懸停
function FileDragHover(e) {
    e.stopPropagation();
    e.preventDefault();
    e.target.className = (e.type == "dragover" ? "hover" : "");
}
「閲覧」を使用して1つ以上のファイルを選択するか、#FileDRAGの場所にファイルをドラッグアンドドロップするかどうかにかかわらず、同じfilesElectHandler()関數(shù)を使用します。

この関數(shù):1。FileDragHover()を呼び出して、Hoverスタイルを削除し、ブラウザイベントをキャンセルします。これは非常に重要です。そうしないと、ブラウザがファイルを表示しようとする場合があります。 2。フィルリストオブジェクトを取得します。これは、ファイル入力ボックス(e.target.files)または#filedrag要素(e.datatransfer.files)からのものです。 3.最後に、ファイルリスト內(nèi)のすべてのファイルオブジェクトを介して関數(shù)がループし、parsefile()関數(shù)のパラメーターとしてそれらを渡します...

<fieldset><legend>HTML文件上傳</legend>
<div>
  <input type="file" id="fileselect" name="fileselect[]" multiple="multiple">
  <label for="fileselect">選擇要上傳的文件:</label>
  <div id="filedrag">或?qū)⑽募戏诺酱颂?lt;/div>
</div>
<input type="submit" value="上傳文件" id="submitbutton">
</fieldset>
<div id="messages">狀態(tài)信息</div>
この関數(shù)は、ファイルオブジェクトによって提供された3つの主要な読み取り専用屬性を使用して出力情報(bào)を出力します。 - .size:ファイルサイズ(バイト)。

Firefox、Chrome、またはOperaのデモページをご覧ください(ドラッグアンドドロップサポートなし)。ファイルをダウンロードしてコードを確認(rèn)することもできます。私たちはたくさんカバーしました。私の次の投稿では、html5とjavascriptを使用してドラッグアンドドロップファイルを開く方法について

この記事は、あなたが好きな場合はアルメニア人に翻訳されています。この記事を読むと、學(xué)習(xí)可能な場所が大好きです。メンバーは、現(xiàn)実世界のHTML5やCSS3など、すべてのSetePointの電子書籍とインタラクティブなオンラインコースに即座にアクセスできます。この記事のコメントは閉じられています。 HTML5について質(zhì)問はありますか?フォーラムで質(zhì)問してみませんか? HTML5ファイルのドラッグアンドドロップに関するfaq * (記事の長さのために、次のFAQパーツは省略されています。必要に応じて、FAQパーツの翻訳を個(gè)別にリクエストできます。)

以上がHTML5ファイルのドラッグアンドドロップの使用方法の詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國語 Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

寫真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中國語版

SublimeText3 中國語版

中國語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強(qiáng)力な PHP 統(tǒng)合開発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Garbage CollectionはJavaScriptでどのように機(jī)能しますか? Garbage CollectionはJavaScriptでどのように機(jī)能しますか? Jul 04, 2025 am 12:42 AM

JavaScriptのごみ収集メカニズムは、タグクリアリングアルゴリズムを介してメモリを自動的に管理して、メモリ漏れのリスクを減らします。エンジンはルートオブジェクトからアクティブオブジェクトを橫斷およびマークし、マークされていないオブジェクトはゴミとして扱われ、クリアされます。たとえば、オブジェクトが參照されなくなった場合(変數(shù)をnullに設(shè)定するなど)、次のリサイクルでリリースされます。メモリリークの一般的な原因には以下が含まれます。 closurures閉鎖の外部変數(shù)への參照。 globalグローバル変數(shù)は引き続き大量のデータを保持しています。 V8エンジンは、世代のリサイクル、増分マーキング、並列/同時(shí)リサイクルなどの戦略を通じてリサイクル効率を最適化し、メインスレッドのブロック時(shí)間を短縮します。開発中、不必要なグローバル?yún)⒄栅虮埭?、パフォーマンスと安定性を改善するためにオブジェクトの関連付けを迅速に裝飾する必要があります。

node.jsでHTTPリクエストを作成する方法は? node.jsでHTTPリクエストを作成する方法は? Jul 13, 2025 am 02:18 AM

node.jsでHTTPリクエストを開始するには、組み込みモジュール、axios、およびnode-fetchを使用する3つの一般的な方法があります。 1.依存関係のない內(nèi)蔵http/httpsモジュールを使用します。これは基本的なシナリオに適していますが、https.get()を使用してデータを取得したり、.write()を介してPOSTリクエストを送信するなど、データステッチとエラーモニタリングの手動処理が必要です。 2.Axiosは、約束に基づいたサードパーティライブラリです。簡潔な構(gòu)文と強(qiáng)力な機(jī)能を備えており、非同期/待ち聲、自動JSON変換、インターセプターなどをサポートします。非同期リクエスト操作を簡素化することをお勧めします。 3.Node-Fetchは、約束と単純な構(gòu)文に基づいて、ブラウザフェッチに似たスタイルを提供します

JavaScriptデータ型:プリミティブ対參照 JavaScriptデータ型:プリミティブ対參照 Jul 13, 2025 am 02:43 AM

JavaScriptデータ型は、プリミティブタイプと參照タイプに分割されます。プリミティブタイプには、文字列、數(shù)字、ブール、ヌル、未定義、シンボルが含まれます。値は不変であり、コピーは値を割り當(dāng)てるときにコピーされるため、互いに影響を與えません。オブジェクト、配列、関數(shù)などの參照タイプはメモリアドレスを保存し、同じオブジェクトを指す変數(shù)は互いに影響します。 TypeofとInstanceOFを使用してタイプを決定できますが、TypeOfNullの歴史的な問題に注意してください。これらの2種類の違いを理解することは、より安定した信頼性の高いコードを書くのに役立ちます。

JavaScript Timeオブジェクト、誰かがEACTEXE、Google Chromeなどのより高速なWebサイトを構(gòu)築します。 JavaScript Timeオブジェクト、誰かがEACTEXE、Google Chromeなどのより高速なWebサイトを構(gòu)築します。 Jul 08, 2025 pm 02:27 PM

こんにちは、JavaScript開発者!今週のJavaScriptニュースへようこそ!今週は、DenoとのOracleの商標(biāo)紛爭、新しいJavaScript Timeオブジェクトがブラウザ、Google Chromeアップデート、およびいくつかの強(qiáng)力な開発ツールによってサポートされています。始めましょう! 「JavaScript」の商標(biāo)を登録しようとするDeno Oracleの試みとのOracleの商標(biāo)紛爭は、論爭を引き起こしました。 Node.jsとDenoの作成者であるRyan Dahlは、商標(biāo)をキャンセルするために請願書を提出しました。

React vs Angular vs Vue:どのJSフレームワークが最適ですか? React vs Angular vs Vue:どのJSフレームワークが最適ですか? Jul 05, 2025 am 02:24 AM

どのJavaScriptフレームワークが最良の選択ですか?答えは、あなたのニーズに応じて最も適切なものを選択することです。 1.反応は柔軟で無料で、高いカスタマイズとチームアーキテクチャ機(jī)能を必要とする中規(guī)模および大規(guī)模プロジェクトに適しています。 2。Angularは、エンタープライズレベルのアプリケーションと長期的なメンテナンスに適した完全なソリューションを提供します。 3. Vueは使いやすく、中小規(guī)模のプロジェクトや迅速な発展に適しています。さらに、既存のテクノロジースタック、チームサイズ、プロジェクトのライフサイクル、およびSSRが必要かどうかは、フレームワークを選択する上で重要な要素でもあります。要するに、絶対に最良のフレームワークはありません。最良の選択は、あなたのニーズに合ったものです。

JavaScriptですぐに呼び出された関數(shù)式(IIFE)を理解します JavaScriptですぐに呼び出された関數(shù)式(IIFE)を理解します Jul 04, 2025 am 02:42 AM

iife(即時(shí)インドボークフニックエクスペッション)は、定義の直後に実行される関數(shù)式であり、変數(shù)を分離し、グローバルな範(fàn)囲の汚染を避けるために使用されます。括弧內(nèi)に関數(shù)を包むことによって呼び出され、式と括弧のペアがすぐにそれに続く、(function(){/code/})();そのコアの使用には、次のものが含まれます。1。さまざまな競合を回避し、複數(shù)のスクリプト間の命名の重複を防ぎます。 2。プライベートスコープを作成して、內(nèi)部変數(shù)を見えないようにします。 3。変數(shù)が多すぎずに初期化を容易にするモジュラーコード。一般的なライティング方法には、ES6矢印関數(shù)のパラメーターとバージョンで渡されたバージョンが含まれますが、式とタイを使用する必要があることに注意してください。

ハンドリングの約束:javascriptのチェーン、エラー処理、および約束の組み合わせ ハンドリングの約束:javascriptのチェーン、エラー処理、および約束の組み合わせ Jul 08, 2025 am 02:40 AM

約束は、JavaScriptで非同期操作を処理するためのコアメカニズムです。チェーンコール、エラー処理、コンビナーの理解は、アプリケーションをマスターするための鍵です。 1.チェーンコールは、.then()を通じて新しい約束を返し、非同期プロセスの連結(jié)を?qū)g現(xiàn)します。それぞれ.then()は以前の結(jié)果を受け取り、値または約束を返すことができます。 2。エラー処理は、.catch()を使用して例外をキャッチしてサイレント障害を回避し、キャッチのデフォルト値を返すためにプロセスを継続する必要があります。 3。promise.all()などの組み合わせ(すべての成功後にのみ成功しました)、promise.race()(最初の完了が返されます)、promise.allsettled()(すべての完了を待っています)

キャッシュAPIとは何ですか?また、サービスワーカーでどのように使用されますか? キャッシュAPIとは何ですか?また、サービスワーカーでどのように使用されますか? Jul 08, 2025 am 02:43 AM

Cacheapiは、ブラウザからネットワークリクエストをキャッシュするツールです。これは、ウェブサイトのパフォーマンスとオフラインエクスペリエンスを改善するために、サービスワーカーと併用することがよくあります。 1.開発者は、スクリプト、スタイルシート、寫真などのリソースを手動で保存できるようにします。 2。要求に応じてキャッシュ応答と一致させることができます。 3.特定のキャッシュの削除またはキャッシュ全體のクリアをサポートします。 4.フェッチイベントを聞いているサービスワーカーを介して、キャッシュの優(yōu)先順位またはネットワークの優(yōu)先戦略を?qū)g裝できます。 5.オフラインサポート、繰り返しのアクセス速度の高速化、主要なリソースのプリロード、バックグラウンドアップデートコンテンツによく使用されます。 6.それを使用する場合、キャッシュバージョンの制御、ストレージ制限、およびHTTPキャッシングメカニズムとの違いに注意する必要があります。

See all articles