ホームページ ウェブフロントエンド jsチュートリアル jsでuploadifyのアップロード数を制限する実装

jsでuploadifyのアップロード数を制限する実装

Jun 25, 2018 pm 02:26 PM

この記事では、uploadify を使用してファイルや画像をアップロードする際のアップロード数を制限する方法を説明します。これは非常に簡単で便利で、必要な場合は参考にしてください。

uploadifyのアップロード数を制限する簡単な実装

function deleteUrl(){
   $("body").on("click",".img-wrap .mask span",function(event){
    event.stopPropagation();
          
    var qs=$('#file_upload-queue>p');//所有的队列
    var id=qs.eq(2).attr('id');//得到第三个队列的id
    $('#uploadTowedAccredit').uploadify('cancel',id);//这样就行了,会自动重置队列数量和删除dom对象,不能直接qs.eq(2).remove(),无效
      
    /*
    if(!window.confirm("您确定删除附件?")){
      return;
    }
    var imgUrl=$(this).parents(".img-wrap").find("img").attr("src");
    deleteImage(imgUrl);
    $(this).parents(".img-wrap").remove();
    */
  });
};
ログイン後にコピー

<li class="blockli clearfix" style="padding-bottom: 5px;">
  <span class="left-name"><em class="red-star">*</em>拖机授权委托书:</span>
  <p class="upload-wrap" style="width:100px;">
    <input type="file" name="uploadTowedAccredit" id="uploadTowedAccredit" class="filetext"/>
  </p>
  <span id="uploadTowedAccreditLinkTip" class="warn-tips"><em></em>请上传附件,最多上传${towedAccreditPicMax} 张</span>
  <p id="towedAccreditp" class="up-img-list clearfix"></p>
</li>
ログイン後にコピー

// 上传拖机授权委托书
function uploadTowedAccreditInit(){
   $("#uploadTowedAccredit").uploadify({
    &#39;hideButton&#39;:&#39;true&#39;,
    &#39;preventCaching&#39; : &#39;true&#39;,
    &#39;checkExisting&#39;:&#39;true&#39;,
    &#39;swf&#39;: SWF, 
    &#39;uploader&#39;:uploadImg,
    &#39;debug&#39;:false,
    &#39;multi&#39;: true,
    &#39;method&#39;: &#39;post&#39;,
    &#39;preventCaching&#39; : true,
    &#39;removeCompleted&#39; : true,
    &#39;removeTimeout&#39; : 10,
    &#39;requeueErrors&#39; : true,
    &#39;successTimeout&#39; : 30,
    &#39;uploadLimit&#39; : ${towedAccreditPicMax},
     
    &#39;fileObjName&#39; : &#39;Filedata&#39;,
    //单张图片最大限制
    &#39;fileSizeLimit&#39; : &#39;1024KB&#39;,
    &#39;fileTypeDesc&#39; : &#39;Image Files&#39;,
    //仅限上传jpg格式图片
    &#39;fileTypeExts&#39; : &#39;*.jpg;*.png&#39;,
    &#39;height&#39;: 24,
    &#39;width&#39;:73,
    &#39;buttonText&#39; : &#39;上传附件&#39;,
    &#39;auto&#39;: true,
    &#39;buttonClass&#39;:&#39;uploada btn-fff-24&#39;,
   
    &#39;onSWFReady&#39; : function() {
    },
     
    &#39;onInit&#39;:function(){
      // $("#file_upload-button").css("width","100");
     },
         
    //选择图片完成
    &#39;onSelect&#39; : function() {
 
    },
     
    //取消上传
    &#39;onCancel&#39; : function(file) {
    },
    &#39;onCheck&#39;: function(event,data,key) {
    },
    //开始上传
    &#39;onUploadStart&#39; : function(file) {
      $(&#39;.uploadify-queue&#39;).html(&#39;&#39;);
    },
     
    //上传过程中
    &#39;onUploadProgress&#39; : function(file, bytesUploaded, bytesTotal, totalBytesUploaded, totalBytesTotal) {
      $(&#39;.uploadify-queue&#39;).html(&#39;&#39;);
      $("#uploadTowedAccreditLinkTip").html(&#39;<em></em>上传中...&#39;);
    },
     
    //上传完成
    &#39;onUploadComplete&#39; : function(file) {
        $(&#39;.uploadify-queue&#39;).html(&#39;&#39;);
        $("#uploadTowedAccreditLinkTip").html(&#39;<em></em>上传成功,待提交&#39;);
    },
     
    //上传成功
    &#39;onUploadSuccess&#39; : function(file, data, response) {
      var obj = eval(&#39;(&#39; + data + &#39;)&#39;);
        var result=obj.result;
        if(result=="true"){
          var filename=obj.filename;
          $(&#39;.uploadify-queue&#39;).html(&#39;&#39;);
          $(&#39;#towedAccreditp&#39;).append("<p class=&#39;img-wrap&#39;><img width=&#39;112&#39; height=&#39;84&#39; alt=&#39;&#39; src=&#39;"+filename+"&#39;><p class=&#39;mask&#39;><em></em><span></span></p></p>");
        }
    },
     
    //上传失败 //附件格式不正确,请上传JPG、BMP、PNG格式文件,大小不超过3MB
    &#39;onUploadError&#39; : function(file, errorCode, errorMsg, errorString) {
      switch(errorCode) {
        case -100:
          alert("上传的文件数量已经超出系统限制的"+$(&#39;#uploadTowedAccredit&#39;).uploadify(&#39;settings&#39;,&#39;queueSizeLimit&#39;)+"个文件!");
          break;
        case -110:
          alert("文件 ["+file.name+"] 大小超出系统限制的"+$(&#39;#uploadTowedAccredit&#39;).uploadify(&#39;settings&#39;,&#39;fileSizeLimit&#39;)+"大小!");
          break;
        case -120:
          alert("文件 ["+file.name+"] 大小异常!");
          break;
        case -130:
          alert("文件 ["+file.name+"] 类型不正确!");
          break;
      }
    },
    //上传失败 //附件格式不正确,请上传JPG、BMP、PNG格式文件,大小不超过3MB
    &#39;onSelectError&#39; : function(file, errorCode, errorMsg) { 
      var msgText = "上传失败\n"; 
      switch (errorCode) { 
        case SWFUpload.QUEUE_ERROR.QUEUE_LIMIT_EXCEEDED: 
          var towedAccreditpLen = $("#towedAccreditp").children().length;
          msgText += "每次最多上传 " + $(&#39;#uploadTowedAccredit&#39;).uploadify(&#39;settings&#39;,&#39;uploadLimit&#39;) + "个文件"; 
          break; 
        case SWFUpload.QUEUE_ERROR.FILE_EXCEEDS_SIZE_LIMIT: 
          msgText += "文件大小超过限制( " + $(&#39;#uploadTowedAccredit&#39;).uploadify(&#39;settings&#39;,&#39;fileSizeLimit&#39;) + " )"; 
          break; 
        case SWFUpload.QUEUE_ERROR.ZERO_BYTE_FILE: 
          msgText += "文件大小为0"; 
          break; 
        case SWFUpload.QUEUE_ERROR.INVALID_FILETYPE: 
          msgText += "文件格式不正确,仅限 " + $(&#39;#uploadTowedAccredit&#39;).uploadify(&#39;settings&#39;,&#39;fileTypeExts&#39;); 
          break; 
        default: 
          msgText += "错误代码:" + errorCode + "\n" + errorMsg; 
      }
      alert(msgText);
    }
  });
   
  //判断用户是否有安装flash
 var obj = $("#uploadTowedAccredit").children().eq(0);
 if(obj.attr(&#39;type&#39;)!= "application/x-shockwave-flash"){
    alert(&#39;系统检测到您的浏览器没有安装flash插件,为了你能够正常上传图片,建议你安装flash&#39;);
    return;
  }
   
  $("#uploadTowedAccredit").css("float","left");
};
ログイン後にコピー

さらに、jquery+uploadifyの複数ファイルアップロードが全員に添付されます

<html xmlns=”http://www.w3.org/1999/xhtml”>
<head>
<meta http-equiv=”Content-Type” content=”text/html; charset=UTF-8″ />
<title>php jquery uploadify多文件上传</title>
<link href=”css/default.css” rel=”stylesheet” type=”text/css” />
<link href=”css/uploadify.css” rel=”stylesheet” type=”text/css” />
<script type=”text/javascript” src=”js/jquery-1.3.2.min.js”></script>
<script type=”text/javascript” src=”js/swfobject.js”></script>
<script type=”text/javascript” src=”js/jquery.uploadify.v2.1.0.min.js”></script>
<script type=”text/javascript”>
$(document).ready(function() {
$(“#fileInput2″).uploadify({
‘uploader&#39;: ‘js/uploadify.swf&#39;,//所需要的flash文件
‘cancelImg&#39;: ‘cancel.png&#39;,//单个取消上传的图片
&#39;script&#39;: ‘js/uploadify.php&#39;,//实现上传的程序
‘folder&#39;: ‘uploads&#39;,//服务端的上传目录
//&#39;auto&#39;: true,//自动上传
‘multi&#39;: true,//是否多文件上传
//&#39;checkScript&#39;: ‘js/check.php&#39;,//验证 ,服务端的
‘displayData&#39;: &#39;speed&#39;,//进度条的显示方式
//&#39;fileDesc&#39;: ‘Image(*.jpg;*.gif;*.png)&#39;,//对话框的文件类型描述
//&#39;fileExt&#39;: ‘*.jpg;*.jpeg;*.gif;*.png&#39;,//可上传的文件类型
//&#39;sizeLimit&#39;: 999999 ,//限制上传文件的大小
//&#39;simUploadLimit&#39; :3, //并发上传数据
//&#39;queueSizeLimit&#39; :5, //可上传的文件个数
//&#39;buttonText&#39; :&#39;文件上传&#39;,//通过文字替换钮扣上的文字
‘buttonImg&#39;: ‘css/images/browseBtn.png&#39;,//替换上传钮扣
‘width&#39;: 80,//buttonImg的大小
‘height&#39;: 24,//
‘rollover&#39;: true,//button是否变换
onComplete: function (evt, queueID, fileObj, response, data) {
//alert(“Successfully uploaded: “+fileObj.filePath);
//alert(response);
getResult(response);//获得上传的文件路径
}
//onError: function(errorObj) {
// alert(errorObj.info+” “+errorObj.type);
//}
});
});
</script>
<script type=”text/javascript”>
function getResult(content){
//通过上传的图片来动态生成text来保存路径
var board = document.getElementById(“pTxt”);
board.style.display=””;
var newInput = document.createElement(“input”);
newInput.type = “text”;
newInput.size = “45″;
newInput.name=”myFilePath[]“;
var obj = board.appendChild(newInput);
var br= document.createElement(“br”);
board.appendChild(br);
obj.value=content;
}
</script>
</head>
<body>
<fieldset style=”border: 1px solid #CDCDCD; padding: 8px; padding-bottom:0px; margin: 8px 0″>
<legend> <strong> 多文件上传</strong></legend>
<p>
<input id=”fileInput2″ name=”fileInput2″ type=”file” />
<input type=”button” value=”确定上传” onclick=”javascript:$(‘#fileInput2′).uploadifyUpload();”>  
||  <a href=”javascript:$(‘#fileInput2′).uploadifyClearQueue();”>清除上传列表</a></p>
<p></p>
</fieldset>
<FORM name=”form2″ METHOD=POST ACTION=”db.php”>
 <p id=”pTxt” style=”display:none”><span style=”color:red”><strong>已经上传的图片有:</strong></span& gt;<br></p><br>
<INPUT TYPE=”submit” value=”提 交”>
</FORM>
</body>
</html>
ログイン後にコピー

以上がこの記事の全内容です。皆さんの学習に役立つことを願っています。その他の関連コンテンツについては、PHP 中国語 Web サイトに注目してください。

関連する推奨事項:

jQuery ファイルのアップロード コントロール 分析のアップロード

ReactNative で FlatList を使用する方法

以上がjsでuploadifyのアップロード数を制限する実装の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

独自のJavaScriptライブラリを作成および公開するにはどうすればよいですか? 独自のJavaScriptライブラリを作成および公開するにはどうすればよいですか? Mar 18, 2025 pm 03:12 PM

記事では、JavaScriptライブラリの作成、公開、および維持について説明し、計画、開発、テスト、ドキュメント、およびプロモーション戦略に焦点を当てています。

ブラウザでのパフォーマンスのためにJavaScriptコードを最適化するにはどうすればよいですか? ブラウザでのパフォーマンスのためにJavaScriptコードを最適化するにはどうすればよいですか? Mar 18, 2025 pm 03:14 PM

この記事では、ブラウザでJavaScriptのパフォーマンスを最適化するための戦略について説明し、実行時間の短縮、ページの負荷速度への影響を最小限に抑えることに焦点を当てています。

フロントエンドのサーマルペーパーレシートのために文字化けしたコード印刷に遭遇した場合はどうすればよいですか? フロントエンドのサーマルペーパーレシートのために文字化けしたコード印刷に遭遇した場合はどうすればよいですか? Apr 04, 2025 pm 02:42 PM

フロントエンドのサーマルペーパーチケット印刷のためのよくある質問とソリューションフロントエンド開発におけるチケット印刷は、一般的な要件です。しかし、多くの開発者が実装しています...

ブラウザ開発者ツールを使用してJavaScriptコードを効果的にデバッグするにはどうすればよいですか? ブラウザ開発者ツールを使用してJavaScriptコードを効果的にデバッグするにはどうすればよいですか? Mar 18, 2025 pm 03:16 PM

この記事では、ブラウザ開発者ツールを使用した効果的なJavaScriptデバッグについて説明し、ブレークポイントの設定、コンソールの使用、パフォーマンスの分析に焦点を当てています。

誰がより多くのPythonまたはJavaScriptを支払われますか? 誰がより多くのPythonまたはJavaScriptを支払われますか? Apr 04, 2025 am 12:09 AM

スキルや業界のニーズに応じて、PythonおよびJavaScript開発者には絶対的な給与はありません。 1. Pythonは、データサイエンスと機械学習でさらに支払われる場合があります。 2。JavaScriptは、フロントエンドとフルスタックの開発に大きな需要があり、その給与もかなりです。 3。影響要因には、経験、地理的位置、会社の規模、特定のスキルが含まれます。

ソースマップを使用して、マイナイドJavaScriptコードをデバッグするにはどうすればよいですか? ソースマップを使用して、マイナイドJavaScriptコードをデバッグするにはどうすればよいですか? Mar 18, 2025 pm 03:17 PM

この記事では、ソースマップを使用して、元のコードにマッピングすることにより、Minified JavaScriptをデバッグする方法について説明します。ソースマップの有効化、ブレークポイントの設定、Chrome DevtoolsやWebpackなどのツールの使用について説明します。

Console.log出力の違い結果:なぜ2つの呼び出しが異なるのですか? Console.log出力の違い結果:なぜ2つの呼び出しが異なるのですか? Apr 04, 2025 pm 05:12 PM

Console.log出力の違いの根本原因に関する詳細な議論。この記事では、Console.log関数の出力結果の違いをコードの一部で分析し、その背後にある理由を説明します。 �...

初心者向けのタイプスクリプト、パート2:基本データ型 初心者向けのタイプスクリプト、パート2:基本データ型 Mar 19, 2025 am 09:10 AM

エントリーレベルのタイプスクリプトチュートリアルをマスターしたら、TypeScriptをサポートするIDEで独自のコードを作成し、JavaScriptにコンパイルできるはずです。このチュートリアルは、TypeScriptのさまざまなデータ型に飛び込みます。 JavaScriptには、NULL、未定義、ブール値、数字、文字列、シンボル(ES6によって導入)とオブジェクトの7つのデータ型があります。 TypeScriptはこれに基づいてより多くのタイプを定義し、このチュートリアルではすべてを詳細に説明します。 ヌルデータ型 JavaScriptのように、Typescriptのnull

See all articles