vue3 + three.js 解决报错Uncaught TypeError: ‘get‘ on proxy: property ‘xxx‘ is a read-only and non-conf..

项目场景:

公司项目采用vue3+three,今天做页面截图 ,图片下载产生了一个问题

在这里插入图片描述


问题描述

翻译过来
属性“modelViewMatrix”是代理目标上的一个只读且不可配置的数据属性,但代理没有返回它的实际值(预期为“#”,但得到了“#”)

    screenShots(name:any){
        const s = 15;
        let tempCamera =new OrthographicCamera(-s, s, -s * (this.h / this.w), s * (this.h / this.w), 0, 10000000)
        tempCamera.lookAt(0, 0, 0);
        let image = new Image();
        
        let renderer:WebGLRenderer|null = new WebGLRenderer()
        renderer.setSize(this.w, this.h); 
        renderer.render(this.scene, tempCamera);
        //图片转base64地址 这里可以选择png格式jpeg格式
        let imgData = renderer.domElement.toDataURL("image/png");
         //使用后需要销毁不然会换画面,显示当前的renderer
        renderer = null;
        image.src = imgData;
        image.style.display = 'none'
        document.body.appendChild(image);
        console.log(image);
        
        Download(name,imgData)
    }
renderer.render(this.scene, tempCamera);

注意这里,this.scene是一个proxy对象

这个modelViewMatrix是个私有属性可能无法读取到
在这里插入图片描述

解决方案:

依情况而定

1.不做代理

直接用var 声明,

<script>
//导入
var scene = new Scene();

export default defineComponent({
  name: "xxxx",
  data() {
    //XXXX
  },

  methods: {
  	//XXXXX
  },
});
</script>

2.浅拷贝

方式很多
比如:使用 json.Stringify()

const scene = JSON.parse(JSON.stringify(this.scene));
 renderer.render(scene, tempCamera);

3.toRaw

在这里插入图片描述

 renderer.render(toRaw(this.scene), tempCamera);

本质就是用原对象,不要用代理过的

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值