vue3中如何獲取proxy包裹的數(shù)據(jù)
如何獲取proxy包裹的數(shù)據(jù)
在進(jìn)行 vue3+ts+elementplus 重構(gòu)vue2項(xiàng)目時(shí)遇到了關(guān)于proxy的問(wèn)題
具體問(wèn)題
使用el-upload組件進(jìn)行圖片上傳,然后綁定handleChange方法進(jìn)行圖片改變的監(jiān)聽(tīng),將上傳的圖片push到fileList數(shù)組中。
const handleChange: UploadProps['onChange'] = (file, fileList1) => {
//當(dāng)改變時(shí),將fileList1push到fileList數(shù)組,然后用fileList進(jìn)行之后的處理
fileList.push(fileList1)
console.log('測(cè)試',fileList)
}然后聲明一個(gè)form表單,對(duì)數(shù)組進(jìn)行遍歷,插入form表單。此時(shí)發(fā)現(xiàn)問(wèn)題:fileList是proxy對(duì)象

如圖所示,fileList數(shù)組被proxy包裹
解決辦法
查資料了解到:vue3使用proxy代替vue2的object.defineProperty,相當(dāng)于在對(duì)象前設(shè)置的“攔截”
可以利用序列化獲取,因?yàn)檫@里所取值為數(shù)組第一項(xiàng),所以修改為:
JSON.parse(JSON.stringify(fileList))[0]
輸出如圖

綜上,解決了取出proxy中數(shù)據(jù)的方法,然后就是對(duì)其foreach遍歷等操作
vue3 proxy基本用法
新的改變
- 我們的vue3 使用proxy 來(lái)代替vue2 的 Object.defineProperty
- 效率更高,值得我們學(xué)習(xí)
基本使用
<script>
var target = {
name: "xiaoming",
age: 18
}
// handler 是一個(gè)對(duì)象
const handler = {
set(target, prop, value) {
let result = Reflect.set(target, prop, value)
console.log("設(shè)置的操作" + result)
return true;
},
get(target, value) {
let result = Reflect.get(target, value)
console.log("獲取的的操作" + result)
}
}
let proxy = new Proxy(target, handler);
proxy.coure = "java"
console.log(proxy)
</script>
這個(gè)打印效果:

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
解決Vue使用mint-ui loadmore實(shí)現(xiàn)上拉加載與下拉刷新出現(xiàn)一個(gè)頁(yè)面使用多個(gè)上拉加載后沖突問(wèn)題
這篇文章主要介紹了解決Vue使用mint-ui loadmore實(shí)現(xiàn)上拉加載與下拉刷新出現(xiàn)一個(gè)頁(yè)面使用多個(gè)上拉加載后沖突問(wèn)題,需要的朋友可以參考下2017-11-11
使用vue init webpack項(xiàng)目名創(chuàng)建項(xiàng)目方式
這篇文章主要介紹了使用vue init webpack項(xiàng)目名創(chuàng)建項(xiàng)目方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11
如何利用 vue實(shí)現(xiàn)鼠標(biāo)懸停時(shí)顯示元素或文本
Vue.js 是一種流行的 JavaScript 框架,可以使 Web 應(yīng)用程序的開(kāi)發(fā)變得更加輕松和高效,這篇文章主要介紹了在 vue 中鼠標(biāo)懸停時(shí)顯示元素或文本,需要的朋友可以參考下2023-05-05
vue中動(dòng)態(tài)控制btn的disabled屬性方式
這篇文章主要介紹了vue中動(dòng)態(tài)控制btn的disabled屬性方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
簡(jiǎn)單的vue-resourse獲取json并應(yīng)用到模板示例
本篇文章主要介紹了簡(jiǎn)單的vue-resourse獲取json并應(yīng)用到模板示例,非常具有實(shí)用價(jià)值,需要的朋友可以參考下。2017-02-02
Vue利用watch偵聽(tīng)器模擬實(shí)現(xiàn)翻譯功能
本期將會(huì)介紹 Vue 中的 watch 偵聽(tīng)器,它語(yǔ)法是怎么樣的呢?具有怎樣的功能呢?最后用模擬實(shí)現(xiàn)百度翻譯來(lái)更進(jìn)一步練習(xí) watch 偵聽(tīng)器,需要的朋友可以參考下2024-11-11
vue實(shí)現(xiàn)接口封裝的實(shí)現(xiàn)示例
本文主要介紹了vue實(shí)現(xiàn)接口封裝的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-11-11
vue中h5端打開(kāi)app(判斷是安卓還是蘋(píng)果)
這篇文章主要介紹了vue中h5端打開(kāi)app(判斷是安卓還是蘋(píng)果),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02

