這篇文章給大家分享的是有關(guān)JavaScript如何實(shí)現(xiàn)上傳文件,圖片,視頻功能的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。
江西ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書未來市場(chǎng)廣闊!成為成都創(chuàng)新互聯(lián)公司的ssl證書銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:028-86922220(備注:SSL證書合作)期待與您的合作!
具體代碼如下所示:
// 上傳目標(biāo)觸發(fā)點(diǎn) <input type="file" class="upvideo" name="upvideo" id="fileupload1" /> // 引入插件 <script type="text/javascript" src="{$IMG}/bstage/js/jquery.form.js" language="javascript"></script> /**方法調(diào)用**/ setFileUpload({ name: 'fileupload1', backfun: upback1, beforefun: checkUp1, loadfun:loadup, phpUrl: '/ossphp/php/get.php?ft=video' }); // 上傳前驗(yàn)證 function checkUp1(n){ // 查看視頻大小(mb) var fileObj = document.getElementById(n).files[0]; var relSize = parseInt(fileObj.size/1024/1024); if(relSize > 10){ // 大于10mb alert('提示','視屏超過10MB,請(qǐng)重新上傳!'); return false; } // 查看視頻類型 var tv_id =document.getElementById(n).value;//根據(jù)id得到值 var index= tv_id.indexOf("."); tv_id=tv_id.substring(index).toLowerCase(); if(tv_id!=".rb"&&tv_id!=".rmvb"&&tv_id!=".mp4"&&tv_id!=".flv"){ alert("提示","不是指定視頻格式,重新選擇"); return false; } return true; } //上傳中 function loadup(){ } // 上傳成功后操作 function upback1(data){ // data 成功后的參數(shù) } /**上傳功能封裝**/ function setFileUpload(options){ var n = options.name; var phpUrl = options.phpUrl; var backfun = options.backfun; var beforefun = options.beforefun; var loadfun = options.loadfun; var accessid = ''; var accesskey = ''; var host = ''; var policyBase64 = ''; var signature = ''; var callbackbody = ''; var filename = ''; var dirname = ''; var expire = 0; var upflag = true; if(phpUrl==null || phpUrl==''){console.log('phpurl is null');return false;} if(n==null || n==''){console.log('object is null');return false;} var backfun1 = $.isFunction(backfun) ? backfun : function(success, error){ console.log('no backfun'); }; var beforefun1 = $.isFunction(beforefun) ? beforefun : function(success, error){ return true; }; var loadfun1 = $.isFunction(loadfun) ? loadfun : function(success, error){ return true; }; var obj = $('#'+n); obj.change(function(){ if(beforefun1(n)){ if(n=="fileupload1"){ fileEmb1(n); }else if(n == 'fileupload2'){ fileEmb2(n); }else if(n == 'fileupload3'){ fileEmb3(n); } } }); function fileEmb1(n){ //oss add $("#"+n).attr('name','file'); var file1 = $("#"+n).val(); var fileName = getFileName(file1); phpUrl = phpUrl + '&fname='+fileName; get_signature(); var ldot = fileName.lastIndexOf("."); var filetype = fileName.substring(ldot + 1); $("#"+n).wrap("<form id='myupload1' action='"+host+"' method='post' enctype='multipart/form-data'></form>"); $("#myupload1").prepend("<input type='hidden' value='' name='name' id='name'></input><input type='hidden' value='"+dirname+"."+filetype+"' name='key' ></input><input type='hidden' value='"+policyBase64+"' name='policy' id='policy'></input><input type='hidden' value='"+accessid+"' name='OSSAccessKeyId' id='OSSAccessKeyId'></input><input type='hidden' value='200' name='success_action_status' id='success_action_status' ></input><input type='hidden' value='"+callbackbody+"' name='callback' id='callback'></input><input type='hidden' value='"+signature+"' name='signature' id='signature'></input>"); //speed_width進(jìn)度條類 //percent進(jìn)度數(shù)字類 //load_content上傳區(qū)域 $('#myupload1').ajaxSubmit({ dataType: 'json', //數(shù)據(jù)格式為json data:'', beforeSend: function() { loadfun1(); if(!upflag)return false; upflag=false; }, uploadProgress: function(event, position, total, percentComplete) { $('.upck_b').hide(); $('.videspeed').show(); percentComplete = percentComplete>=100?99:percentComplete; var percentVal = percentComplete + '%'; //獲得進(jìn)度 $('.speed_num').css('width',percentVal); $('.persent_em').html(percentComplete); }, success: function(data) { //成功 $('.load_content').html('<em >圖片上傳</em>'); //上傳成功后還原 $("#"+n).attr('name',''); setFileUpload(options); upflag=true; backfun1(data); }, error:function(xhr){ //上傳失敗 $('.load_content').html('<em >圖片上傳</em>'); upflag=true; } }); } function getFileName(path){ var pos1 = path.lastIndexOf('/'); var pos2 = path.lastIndexOf('\\'); var pos = Math.max(pos1, pos2) if( pos<0 ) return path; else return path.substring(pos+1); } now = timestamp = Date.parse(new Date()) / 1000; new_multipart_params = ''; function send_request(){ var xmlhttp = null; if (window.XMLHttpRequest) { xmlhttp=new XMLHttpRequest(); } else if (window.ActiveXObject) { xmlhttp=new ActiveXObject("Microsoft.XMLHTTP"); } if (xmlhttp!=null && phpUrl) { //phpUrl = '/ossphp/php/get.php?ft=resources'; xmlhttp.open( "GET", phpUrl, false ); xmlhttp.send( null ); return xmlhttp.responseText; } else { alert("Your browser does not support XMLHTTP."); } }; function get_signature() { //可以判斷當(dāng)前expire是否超過了當(dāng)前時(shí)間,如果超過了當(dāng)前時(shí)間,就重新取一下.3s 做為緩沖 now = timestamp = Date.parse(new Date()) / 1000; //if (expire < now + 3) //{ body = send_request() var obj = eval ("(" + body + ")"); host = obj['host'] policyBase64 = obj['policy'] accessid = obj['accessid'] signature = obj['signature'] expire = parseInt(obj['expire']) callbackbody = obj['callback'] dirname = obj['dir'] return true; //} }; }
感謝各位的閱讀!關(guān)于“JavaScript如何實(shí)現(xiàn)上傳文件,圖片,視頻功能”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
新聞名稱:JavaScript如何實(shí)現(xiàn)上傳文件,圖片,視頻功能
標(biāo)題網(wǎng)址:http://jinyejixie.com/article0/iiceoo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、微信公眾號(hào)、ChatGPT、電子商務(wù)、網(wǎng)站設(shè)計(jì)、手機(jī)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)