在Vue项目中,对于一个展示用户个人信息的页面。有以下需求,需要判断用户个人信息是否填充过,如果填充过,需要在页面中展示已填充项(未填充项不展示);如果未填充过,需要在页面中显示另外一种元素(提示用“去完善”个人信息)。

  这时候,我们在页面中有如下元素

  1. <div v-if="userExist">
  2. // 这里展示用户已填充的信息内容
  3. </div>
  4. <div v-else>
  5. <img class="user-pic-tip" src="../../images/no_info.png"/>
  6. <div class="user-info-tip">
  7. <span>暂无基本资料数据</span>
  8. <router-link to="/editUser">
  9. <span class="data-link-to">去完善</span>
  10. </router-link>
  11. </div>
  12. </div>

  data中userExist有默认值——false:

  1. export default {
  2. name: "healthData",
  3. data() {
  4. return {
  5. userExist: false, // 标记用户是否已填充个人信息
  6. }
  7. };
  8. },

  而用户到底有没有填充过个人信息是需要在mounted中通过接口从后端获取数据才可以知道,这里如果是填充过,后端会返回状态码200;如果没有填充过,后端会返回状态码201。

  1. axios.get('/userInfo').then(res => {
  2. if (res.data.data && res.data.status == 200) {
  3. this.userExist = true
  4. // 这里填充对所返回用户数据的解析
  5. }
  6. }

  在上面这种代码情况下,因为userExist默认值为false,所以默认需要展示无数据的页面元素。又因为userExist值得变更需要通过axios请求的方式获取,就会有延时问题,即产生页面闪烁的情况

  

解决方式:

  这种问题我们就可以通过如下方式解决,因为无数据是页面中的元素较少,我们可以跟它们中的图片路径、文字等内容的初始值设置为空,请求结束时再为其重新赋值。

  页面元素部分:

  1. <div v-if="userExist">
  2. // 这里展示用户已填充的信息内容
  3. </div>
  4. <div v-else>
  5. <img class="user-pic-tip" :src="noDataTip.imgSrc"/>
  6. <div class="user-info-tip">
  7. <span>{{noDataTip.tipInfo}}</span>
  8. <router-link to="/editUser">
  9. <span class="data-link-to">{{noDataTip.jumpEditUser}}</span>
  10. </router-link>
  11. </div>
  12. </div>

  在data中进行声明:

  1. export default {
  2. name: "healthData",
  3. data() {
  4. return {
  5. userExist: false, // 标记用户是否已填充个人信息
  6. noDataTip: { // 用户未填写个人信息时要显示的页面元素的填充内容
  7. imgSrc: '',
  8. tipInfo: '',
  9. jumpInfo: ''
  10. }
  11. }
  12. };
  13. },

  重新赋值的过程:

  1. axios.get('/userInfo').then(res => {
  2. if (res.data.status == 10001) {
  3. return context.noDataTip = {
  4. imgSrc: require('../../images/no_data.png'),
  5. tipInfo: '暂无基本资料数据',
  6. jumpInfo: '去完善'
  7. }
  8. }
  9. if (res.data.data && res.data.status == 200) {
  10. this.userExist = true
  11. // 这里填充对所返回用户数据的解析
  12. }
  13. }

  通过这种方式,用户就不会看到闪烁的情况了。但是,上面这种方式有一个值得注意的地方,img标签的src属性如果想要通过属性绑定的方式给其动态赋值,有两种处理方式:1.通过上面代码中的 require('') 方式;2.通过书写绝对路径的方式。

  属性绑定相关内容可以查看这篇文章:https://www.cnblogs.com/belongs-to-qinghua/p/10939900.html

解决vue更新默认值时出现的闪屏问题的更多相关文章

  1. PostgreSQL中实现更新默认值(二)

    今天我们用表继承+触发器的方案,来实现表中的更新默认值.这也许是PostgreSQL里最佳的解决方案. 一. 创建一张表,作为父表 create table basic_update( t_updat ...

  2. 解决Vue编译和打包时频繁内存溢出情况CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory

    解决Vue编译和打包时频繁内存溢出情况CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 如上图所示:频繁出现此 ...

  3. Lombok的使用详解(最详尽的解释,覆盖讲解所有可用注解),解决@Builder.Default默认值问题

    原文:https://blog.csdn.net/f641385712/article/details/82081900 前言 Lombok是一款Java开发插件,使得Java开发者可以通过其定义的一 ...

  4. model中设置默认值时 ,使用 lambda 与否的差别以及datetime的默认值方法

    'date': '2013-01-01'  #固定值 'date': time.strftime('%Y-%m-%d')  #启动时候的值 'date': lambda *a: time.strfti ...

  5. 解决svn更新项目目录时“Error:svn: E155037: Previous operation has not finished; run 'cleanup' if it was interrupted”的报错问题

    今天在IDEA更新项目目录时,发现报错“Error:svn: E155037: Previous operation has not finished; run 'cleanup' if it was ...

  6. Vue checkbox默认值改变

    <label><input  v-bind:true-value="1" v-bind:false-value="0" type=" ...

  7. SqlServer修改某个字段的默认值时的操作步骤

    sqlserver有时候需要修改一个字段的默认值,却发现修改(update)不了,也删除(delete)不了,排查发现,需要先删除原有的默认值约束,才行:步骤如下1.2.3.若原来这个字段就没有默认值 ...

  8. [转]解决Eclipse更新ADT插件时遇到的Eclipse reports rendering library more recent than ADT plug-in问题

    使用 SDK Manager 工具更新下载新版本后,无法显示可视化布局,同时提示 This version of the rendering library is more recent than y ...

  9. vue store获取值时 Computed property "activeTag" was assigned to but it has no setter.

    出现原因: element-ui中 el-tab绑定的值在切换tab时会自动修改 而activeTag是从store中获取的值,不能直接修改 要添加给它绑定上set   <el-tabs cla ...

随机推荐

  1. python重要的日志模块logging

    一,logging模块简介 logging模块是Python内置的标准模块,主要用于输出运行日志,可以设置输出日志的等级.日志保存路径.日志文件回滚等:相比print,具备如下优点: 1.可以通过设置 ...

  2. android studio :Timeout waiting to lock daemon addresses registry

    一.开发中 android studio 突然遇到下面的错误提示: Error:Timeout waiting to lock daemon addresses registry. It is cur ...

  3. redhat 7.6安装kvm

    安装 yum install qemu-kvm libvirt virt-install virt-manager openssh-askpass yum install qemu-kvm-tools ...

  4. 爬虫,工具 - Splash

    What is it? Splash is a javascript rendering service. It's a lightweight web browser with an HTTP AP ...

  5. JavaSE复习~运算符与表达式

    运算符 运算符:进行特定操作的符号 表达式:用运算符进行操作的式子 算术运算符 首先是加减乘除:+.-.*./还有取余:% 整数进行算术操作得到的还是整数,例如整数使用 / 得到的是整数(商的整数部分 ...

  6. PAT 1007 Maximum Subsequence Sum (最大连续子序列之和)

    Given a sequence of K integers { N1, N2, ..., *N**K* }. A continuous subsequence is defined to be { ...

  7. 《Web安全攻防 渗透测试实战指南》 学习笔记 (二)

    Web安全攻防 渗透测试实战指南   学习笔记 (二)   第二章  漏洞环境及实践  

  8. 【代码学习】PHP面向对象之封装与继承

    一.封装(访问控制) 就是将属性私有,并提供公有的setter放置与getter取值方法注:封装是进行访问控制,不是拒绝访问             public(公有)    protected(受 ...

  9. phpstudy所需运行库

    百度云链接:http://pan.baidu.com/s/1jIu0v7C 密码:j1qu

  10. Windowserver2012服务器激活方法(亲测可用)---转载

    Windowserver2012服务器激活方法(亲测可用)原创꧁刘向洋꧂ 最后发布于2019-03-12 14:46:45 阅读数 5124  收藏展开激活方式 slmgr /ipk D2N9P-3P ...