欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 前端技术 > vue >内容正文

vue

vue 拷贝 数组_vue 使用lodash实现对象数组深拷贝操作

发布时间:2023/12/1 vue 48 豆豆
生活随笔 收集整理的这篇文章主要介绍了 vue 拷贝 数组_vue 使用lodash实现对象数组深拷贝操作 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

我就废话不多说了,大家还是直接看代码吧~

export default {

mounted() {

this.init();

},

methods: {

init() {

let lodash = require('lodash');

let obj1 = {

a: 1,

b: { f: { g: 1 } },

c: [1, 2, 3],

h: () => {

return 123;

},

k: undefined

};

let obj2 = lodash.cloneDeep(obj1);

obj2.b.f.g = 2;

obj2.c = [1, 2];

obj2.h = 1;

console.log(obj1);

console.log(obj2);

}

}

};

如果本篇文章对你有帮助的话,很高兴能够帮助上你。

补充知识:vue iview上传多文件只发送一次ajax请求,并根据上传进度显示上传进度条

前言

基于iview的上传组件(Upload)以及进度条组件(Progress)

思路

使用Upload组件提供的上传文件之前的钩子,将所有上传文件拦截下来,保存在本地临时数组,使用axios来进行上传

完整示例

进度条部分,请上传一个大文件来查看效果

:before-upload="handleUpload"

:action="''"

:multiple="true"

>

请选择附件

  • v-for="(item, index) of formData.dispalyFile"

    :key="index"

    >

    {{ item.name }}

import axios from 'axios';

export default {

data() {

return {

formData: {

dispalyFile: [] // 临时数组,同时用于显示在页面

},

// 上传配置

upload: {

look: true, // 控制多文件上传,只触发一次ajax请求

fileProgressShow: false, // 进度条

fileProgress: 0 // 进度条进度

}

};

},

methods: {

handleUpload(selectFile) {

// 临时数组,同时用于显示在页面

this.formData.dispalyFile.push(selectFile)

// 控制多文件上传,只触发一次ajax请求

if (this.upload.look) {

this.upload.look = false;

// 延迟请求,等待所有文件都从本地读取完毕

setTimeout(() => {

let formData = new FormData();

this.formData.dispalyFile.map(item => {

// files为后台接收参数

// []为多文件数组

formData.append('files[]', item);

})

axios.request({

url: '/upload',

method: 'post',

data: formData,

headers: { 'Content-Type': 'multipart/form-data' },

onUploadProgress: (progressEvent) => {

// 用于上传过程中显示进度条

if (progressEvent.lengthComputable) {

// 显示进度条

this.upload.fileProgressShow = true;

// 计算当前进度

let curValue = (progressEvent.loaded / progressEvent.total * 100).toFixed(0);

// 赋值给进度条组件

this.upload.fileProgress = parseInt(curValue);

}

}

})

.then(res => {

// 上传成功处理

// 隐藏进度条

this.upload.fileProgressShow = false;

})

.catch(() => {

// 上传失败处理

// 隐藏进度条

this.upload.fileProgressShow = false;

})

}, 50);

}

return false;

}

}

};

.upload {

width: 40%;

}

效果图

上传多文件,只进行了一次ajax请求,这里xlz是一个超大压缩包,用于展示进度条效果, binary 为二进制文件

如果本篇文章对你有帮助的话,很高兴能够帮助上你。希望能给大家一个参考,也希望大家多多支持脚本之家。

总结

以上是生活随笔为你收集整理的vue 拷贝 数组_vue 使用lodash实现对象数组深拷贝操作的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。