计算属性传参
computed: { activeUsers: function () { return this.users.filter(function (user) { return user.isActive }) } }处理高频度执行的函数,首次执行之后,在规定的时间内没有再次触发则执行,如果触发则会重新计算过期时间 效果:短时间大量触发同一事件,只会执行一次函数
function debounce(fn,delay){ let timer = null return function(){ if(timer){ clearTimeout(timer) timer = setTimeOut(fn,delay) }else{ timer = setTimeOut(fn,delay) } } }短时间内触发同一事件,那么在函数执行一次之后,在指定的时间内触发则需要过了冷却事件之后才会再次触发
function trottle(fn,delay){ let empty = true return function(){ if(!empty){ return } setTimeout(()=>{ fn empty = true },delay) } }其实根据浏览器的不同而不同,我的谷歌发送了1300多张上传图片的请求就挂掉了,出现net::ERR_INSUFFICIENT_RESOURCES,写一个笨拙的vue的解决办法
<template> <div class="hello"> <h1>{{ msg }}</h1> <input multiple type="file" name="file" value="请选择文件" accept=".png, .jpg, .jpeg" @change="fileChange($event)" /> </div> </template> <script> import moment from "moment"; import axios from "../http/index"; export default { name: 'HelloWorld', props: { msg: String }, data(){ return { sendRequestArr:[], fillListArr:[] } }, methods:{ fileChange(e){ const tcp = 6 for(let file of e.target.files){ this.fillListArr.push(file) } let timestamp=moment(new Date()).format('YYYYMMDDHHmmss') //这个时间戳并不重要,我写的后端是根据时间戳来创建文件夹的 let tempFillList = this.fillListArr.splice(0,tcp) for(let i = 0;i < tempFillList.length ; i++){ let data = new FormData() let file = tempFillList[i] data.append('file' , file) this.sendRequest(data,timestamp,i) } }, sendRequest(data,timestamp,index){ this.sendRequestArr[index] = false axios.post("/api/upload",data,{ headers: { 'time': timestamp, 'index': index } }).then(() =>{ this.sendRequestArr[index] = true if(this.fillListArr.length){ let data = new FormData() let file = this.fillListArr[0] data.append('file' , file) this.fillListArr = this.fillListArr.splice(1,this.fillListArr.length - 1) this.sendRequest(data,timestamp,index) }else{ let finishedAll = this.sendRequestArr.every((finished)=>{ return finished }) if(finishedAll){ this.sendRequestArr = [], this.fillListArr = [] } } }).catch(err =>{ let data = new FormData() let file = this.fillListArr[0] data.append('file' , file) this.fillListArr = this.fillListArr.splice(1,this.fillListArr.length - 1) this.sendRequest(data,timestamp,index) console.log(err) }) }, } } </script>基本思想就是根据浏览器对于同一个域名下的请求最大并行量来规定初始的发送请求数量,比如我这里是六个,首先发送六个,并且记录每一个是否完成,当完成的时候,就截取等待上传的数组然后进行上传,直到等待上传数组为空就不会再发送请求,等到待上传数组为空并且状态数组中都完成了,那么都回到初始位置
另外记录一下用XMLHttpRequest发送请求的方法 filexhr(e){ let files = e.target.files let timestamp=moment(new Date()).format('YYYYMMDDHHmmss') for(let file of files){ let data = new FormData() let request = new XMLHttpRequest(); request.open('POST', "/api/upload",true); request.setRequestHeader("time",timestamp); data.append('file' , file) request.onload = function(e){ console.log(request,e) } request.onerror = function(){ console.log("请求失败") } request.ontimeout = function() { console.error("请求超时") } request.send(data); } } 另外写一下与element ui结合并且不改变onchange的写法 <el-upload drag multiple name="file" :action="yourUrl" :show-file-list="false" :with-credentials="true" accept=".png, .jpg, .jpeg" :on-change="onUploadChange" :http-request="uploadfile" > </el-upload> <script> export default { data(){ retrun{ fileListArr:[], statusListArr:[] } }, //其实思想就是上面的思想,我想展示的只有可以在http-request的参数中可以调用onError和onSuccess方法,这样就不会影响你的on-change函数,并且函数中需要传递服务器返回的response,否则你掉用这个函数之后触发onchange并不能拿到response这个值 methods:{ uploadfile(data){ const tcp = 6 let len = this.statusListArr.length if(len < tcp){ this.sendResquest(len,data) }else{ this.fileListArr.push(data) } }, sendResquest(len,data){ const { file, filename:name, action } = data this.statusListArr[len] = false let formData = new FormData() formData.append(name , file) this.$axios .post(action,formData) .then(res=>{ this.statusListArr[len] = true data.onSuccess(res.data) if(this.fileListArr.length){ this.sendResquest(len,this.fileListArr[0]) this.fileListArr = this.fileListArr.splice(1,this.fileListArr.length - 1) }else{ let finishedAll = this.statusListArr.every((finished)=>{ return finished }) if(finishedAll){ this.statusListArr = [], this.fileListArr = [] } } }) .catch(err=>{ if(this.fileListArr.length){ this.sendResquest(len,this.fileListArr[0]) this.fileListArr = this.fileListArr.splice(1,this.fileListArr.length - 1) }else{ let finishedAll = this.statusListArr.every((finished)=>{ return finished }) if(finishedAll){ this.statusListArr = [], this.fileListArr = [] } } data.onError(err.response) }) }, onUploadChange(){ console.log(886) } } } </script>vue-waterfall
vue-json-viewr
element ui抽屉组件出现黑框并不是因为border而是用的是outline属性
他的抽屉组件内容区域使用的是语义化标签
table组件设置max-height之后并不会有什么问题,但是当他的数据进行异步获取之后,就会出现大的bug,你就会发现他的宽度被扩大了。