Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 451|回复: 0

记录vue在实际工作项目中遇到的问题及解决方案

[复制链接]
  • TA的每日心情
    奋斗
    4 天前
  • 签到天数: 802 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726006
    发表于 2021-7-10 04:08:32 | 显示全部楼层 |阅读模式

        该篇博客主要记录本人在用vue开发实际项目中遇到的毕竟容易碰到和不易发觉的问题及解决方案,下面所贴的代码来自我做的实际项目。

    如果大家有更好的解决方案欢迎留言评论

    一.tab切换值不显示

        修改前的代码(无关代码已去除),此时来回切换tab,详细信息组件(富文本组件)值不显示

    <template>
      <el-tabs v-model="activeName" @tab-click="handleClick">
        <el-tab-pane label="详细信息" name="exactlyInfo">
           <exactly-info  v-bind="$attrs" ></exactly-info>
        </el-tab-pane>
        <el-tab-pane :label="changeLogTitle" name="changeLog">
            <keep-alive>
                <component ref="changeLog"  v-bind:is="changeLog" "></component>    //动态组件
            </keep-alive>
        </el-tab-pane>
      </el-tabs>
    </template>
    <script>
    const exactlyInfo = resolve => require(['./exactlyInfo.vue'], resolve)  //外部引入组件,富文本组件
    const changeLog= resolve => require(['./changeLog.vue'], resolve)  //外部引入组件
    export default {
        data () {
            return {
                activeName: 'exactlyInfo',
                exactlyInfo,
                changeLog,
            };
        },
        components: {
            'exactly-info': exactlyInfo
        },
        
        methods: {
            handleClick (tab, event) {  //tab切换显示对应组件
                switch (tab.name) {
                case 'exactlyInfo':
                    this.exactlyInfo = exactlyInfo;
                    break;
                case 'changeLog':
                    this.changeLog = changeLog
                    break;
                }
            }
        }
    };
    </script>

     修改后的代码

    <template>
      <el-tabs v-model="activeName" @tab-click="handleClick">
        <el-tab-pane label="详细信息" name="exactlyInfo">
           <exactly-info  v-bind="$attrs"v-if="isShowExactlyInfo"></exactly-info>
        </el-tab-pane>
        <el-tab-pane :label="changeLogTitle" name="changeLog">
            <keep-alive>
                <component ref="changeLog"  v-bind:is="changeLog" "></component> //动态组件 </keep-alive> </el-tab-pane> </el-tabs> </template> <script> const exactlyInfo = resolve => require(['./exactlyInfo.vue'], resolve) //外部引入组件,富文本组件 const changeLog= resolve => require(['./changeLog.vue'], resolve) //外部引入组件 export default { data () { return { activeName: 'exactlyInfo', exactlyInfo, changeLog,
                  isShowExactlyInfo: true,
     }; }, components: { 'exactly-info': exactlyInfo }, methods: { handleClick (tab, event) { //tab切换显示对应组件 switch (tab.name) { case 'exactlyInfo': this.exactlyInfo = exactlyInfo;
                      this.isShowExactlyInfo = true  //新增
     break; case 'changeLog': this.changeLog = changeLog
               this.isShowExactlyInfo = false //新增
                    break;
                }
            }
        }
    };
    </script>

    解决方法:通过vue的v-if控制组件的显示隐藏来达到重新渲染组件效果

     

    二.子组件中的方法先于父组件中的方法执行,导致子组件接收到父组件的值为空。

          解决方法:通过vue的v-if先让父页面默认隐藏,待父页面初始化完成再显示,直接上代码

     

    <template>
        <div v-if="isShowPage"> 
    <child-component :data="parentData"></child-component> //子组件有自己的执行方法和生命周期,可能会先于父组件执行,此时parentData就为空
    </div>
    </template>
    <script>
    export
    default {
    data(){
    reutrn {
    isShowPage:
    false ,
               parentData: {}
     } 
    }
    mounted(){
    this.init() },
    methods:{
    init(){ //初始化方法
    this.parentData={name:'parent'} //父组件给子组件传值
    this.isShowPage=true
    }
    }
    }

    </script>

     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-11-15 06:52 , Processed in 0.067744 second(s), 30 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表