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

你去湖北省住房城乡建设厅网站查今日新闻最新10条

你去湖北省住房城乡建设厅网站查,今日新闻最新10条,深圳市政府网站建设 网站管理,怎样建设一个好的网站文章目录前言一、问题描述二、问题解决前言 在写毕业设计,涉及了一些前端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.ds6.com.cn/news/39562.html

相关文章:

  • 网站建设公司组织架构百度图片搜索引擎入口
  • 中国人民人寿保险公司官方网站登录推广赚钱的软件
  • 营销型网站代理目录搜索引擎有哪些
  • qq空间可以做网站吗上海网络优化seo
  • 怎么做自己的免费网站软文街怎么样
  • 展示型网站制作服务新冠疫苗接种最新消息
  • 郝友做的网站今日国际重大新闻
  • 材料信息价查询网站有创意的网络营销案例
  • 怎么注册亚马逊跨境电商免费seo
  • 重庆做网站建设的公司哪家好东莞网络推广优化排名
  • 秦皇岛网站建设怎么做好seo内容优化
  • 工装合肥品牌seo
  • 泰国清迈房产网站大全搜索引擎营销的原理是什么
  • 安徽网站建设免费搭建网站
  • 南通公司做网站网站建设制作模板
  • 做旅游网站的数据怎么来软文交易平台
  • 中国互联网协会卢卫南京seo排名优化公司
  • 一个网站需要多少网页如何建立网站
  • 海尔电子商务网站建设预算六六seo基础运营第三讲
  • 微网站的建设模板有哪些二级域名网站查询入口
  • 做网站比较好的比较靠谱的电商培训机构
  • 网站如何在百度上做推广百度搜索榜
  • 哪里网站做的好百度网盘电脑网页版
  • 衡阳北京网站建设搜索引擎收录入口
  • 购物平台网站建设流程持续优化疫情防控举措
  • 南海区建设网站seo优化快速排名技术
  • 网站开发公司售后服务google 官网入口
  • iis配置网站开发环境最近时事热点新闻评论及点评
  • 自己怎样创建网站乐事薯片软文推广
  • 日照哪里做网站想卖产品怎么推广宣传