当前位置: 首页 > news >正文

网站建设 18556502558苏州姑苏发布最新公告

网站建设 18556502558,苏州姑苏发布最新公告,网站开发毕设论文,北京外包公司 网站开发文章目录前言一、问题描述二、问题解决前言 在写毕业设计,涉及了一些前端Vue.js的组件传值知识并出现了相关问题,因此进行记录。 问题 Vue.js的使用不熟练,相关组件、props等掌握不清晰前端代码书写不规范 望指正! 一、问题描述 …

文章目录

  • 前言
  • 一、问题描述
  • 二、问题解决


前言

在写毕业设计,涉及了一些前端Vue.js的组件传值知识并出现了相关问题,因此进行记录。

问题

  1. Vue.js的使用不熟练,相关组件、props等掌握不清晰
  2. 前端代码书写不规范

望指正!


一、问题描述

想要搭建一个模型检验的页面,在点击按钮“开始检测”后,后端会获取相应数据、页面跳转并进行渲染。
主要涉及三个页面:index.vue、BorderCard.vue、CardResult.vue,如图1:
在这里插入图片描述
index.vue想要引入“步骤条”实现两个组件的切换效果,如图2:
在这里插入图片描述

index.vue中引入两个组件的部分:

<border-card v-show="active === 0" :tab-index="active"/>
<card-result v-show="active === 1" />

相关部分代码如下:

// BorderCard.vue
<template>
<el-button style="position: absolute;top:-48px;right:20px;z-index: 999999;" @click="next">立即检测</el-button>
</template>
<script>
methods: {next() {/** 点击立即检测按钮后,发送请求从后端获取数据(图表模型的正确率,数据信息等),然后利用 this.$emit -> 父组件 -> CardResult.vue*/console.log('handleModelTrain....');this.$http.post('').then(res => {console.log('handleModelTrain=>', res);this.$emit('next', res.data.data)}).catch(() => {this.$message.error('模型训练异常')})},
}
</script>
// index.vue
<template>
<border-card v-show="active === 0" :tab-index="active" @next="handleNextTabs" />
<card-result v-show="active === 1" :model-report="modelReport" />
</template>
<script>
methods: {handleNextTabs(data) {console.log('recall=>', data);if (!data) {this.$message.error('模型训练异常')}// 数据解析this.show_info.total = data.data_totalthis.modelReport = dataif (this.active++ > 1) this.active = 0;},
}
// CardResult.vue
<script>
props: {modelReport: {type: Object,default: () => {return {score: 0,report: ''}}}},watch: {modelReport: {handler: function(newVal, oldVal) {console.log('watch modelReport=>', newVal, oldVal);// 更新图表this.getEchartDataInit(false)// 更新表格this.getTableDataForReport(newVal)},deep: true}}

单独呈现 CardResult.vue组件如图
在这里插入图片描述
当组件切换后,下面数据报告正常显示,但是图像发生了变形:
在这里插入图片描述

二、问题解决

查阅相关文章,其中原因包括:

  • 采用v-show控制切换时,v-show为false时,echarts图并不能获取外部容器的正常宽高,所以展示出来的图形会以其自身默认的大小展示;解决方法-> 在切换到图时重新调用图组件

根据上面说法,我理解的是切换组件的时候重新进行加载,相关博客建议使用组件 :key 属性,当发生变化后会重新加载组件,代码如下:

<border-card v-show="active === 0" :key="active" :tab-index="active" @next="handleNextTabs" />
<card-result v-show="active === 1" :key="!active" :model-report="modelReport" />

更改后的效果如图:
在这里插入图片描述

  • 此处组件传值失效的具体原因不清楚。是否和组件传值先被props接受,然后发生了组件重新加载有关

因此查找相关问题:Vue刷新后页面数据丢失问题的解决过程
解决方案:使用 SessionStorage 进行处理。
相关部分代码如下:

// index.vue
<script>
methods: {handleNextTabs(data) {console.log('recall=>', data);if (!data) {this.$message.error('模型训练异常')}this.show_info.total = data.data_totalthis.modelReport = data// 将数据存储到sessionStoragesessionStorage.setItem('modelReport', JSON.stringify(this.modelReport))if (this.active++ > 1) this.active = 0;}
}
</script>
// CardResult.vue
<script>
created() {console.log('CardResult created...');if (sessionStorage.getItem('modelReport')) {this.modelReport = sessionStorage.getItem('modelReport') // 获取数据直接更新}},beforeDestroy() {// 毁灭前先移除掉,否则我跳转到其它地方,sessionStorage里面依旧存在着console.log('CardResult beforeDestroy...');sessionStorage.removeItem('modelReport')}
}
</script>

然而发生下列错误,如图:
在这里插入图片描述
为了避免直接改变prop中的值,因此我考虑继续使用 this.$emit -> index.vue,由于此时组件没有发生切换,因此不会触发组件的重新加载,然后实现赋值

修改后,部分相关代码如下:

// CardResult.vue
<script>
created() {console.log('CardResult created...');if (sessionStorage.getItem('modelReport')) {this.$emit('refreshData', JSON.parse(sessionStorage.getItem('modelReport')))}},beforeDestroy() {// 毁灭前先移除掉,否则我跳转到其它地方,sessionStorage里面依旧存在着console.log('CardResult beforeDestroy...');sessionStorage.removeItem('modelReport')}
}
</script>
<template><border-card v-show="active === 0" :key="active" :tab-index="active" @next="handleNextTabs" /><card-result v-show="active === 1" :key="!active" :model-report="modelReport" @refreshData="refreshDataParent" />
</template>
<script>
methods: {refreshDataParent(val) {console.log('refreshDataParent recall...');this.modelReport = val}
}
</script>

运行结果如图,目前能够正常显示:
在这里插入图片描述


http://www.vuetechworld.com/news/90/

相关文章:

  • 巴中移动网站建设软件开发制作的公司
  • 产品网站怎么做网站建设的企业目标
  • 织梦网站404页面模板淄博seo定制
  • 网站建设中html中关于图片显示的标签有哪些建筑工程管理局官网
  • 搭建一个企业网站珠海企业宣传片制作
  • 家政公司网站模板软件工程和网络工程哪个好
  • 如何自己写一个网站wordpress边栏小工具
  • app 微信 网站三合一网站做跳转会有什么影响
  • 商城网站建设 优帮云wordpress 4.4.1下载
  • 做贸易的都有什么网站投资电商需要多少钱
  • 贵阳网站建设是什么国外网站icp备案
  • 免费下载网站模板深圳做营销网站的公司简介
  • 郑州网站建设知乎云主机玩游戏怎么样
  • 怎样学电商赚钱短视频seo推广
  • 网站后台上传的照片模糊福州网站建设印秀
  • 地方网站阿里云网站开发服务器
  • 北京网站seo招聘做前端网站要注意哪些
  • 电子商务网站开发实训docker 搭建 wordpress
  • 看网站建设公司的网站案例企业网站建设应注意什么
  • 网站建设实验分析创意礼品私人定制
  • 关于做暧暧的网站wordpress手机上传图片失败
  • 网站开发费会计处理wordpress最好的免费主题2018
  • 江门找人做网站排名效果图是怎么做出来的
  • 教育网站前置审批php 网站开发工程师
  • 昆山公司网站建设电话linux建站和wordpress
  • 长沙品质网站建设优点黄骅港股票代码
  • 浏览器怎么打开网站服务器设置谷歌优化技巧
  • 黑龙江网站建设基于中小企业需求的电子商务网站建设
  • 沈阳专业做网站漯河 做网站
  • 如何对网站做进一步优化网站开发什么技术路线