我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何解决vue的component标签渲染问题

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何解决vue的component标签渲染问题

这篇文章主要介绍了如何解决vue的component标签渲染问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

component标签渲染问题

最近遇到一个问题,就是通过LoadJs方法加载的组件怎么通过component实现热加载问题

vue的component标签是个虚拟dom,在真实dom树上需要vue进行渲染,显示。而我最近遇到的问题,我通过LoadJS方法,从A项目读取B项目的对象,页面并已组件的形式渲染到A项目页面上,组件没法渲染。

我第一反应 是this.$forceUpdate(),渲染一下就是,可是并没有成功。

然后想到一个问题VUE如何识别加载虚拟DOM和如何识别路由里绑定的页面?import对象和require对象有什么区别,什么时候用

想了一堆这类的问题,实际上import和require的区别,好多文章都有说明,而且解释的很好。个人看来最大的区别就是一个是静态编译和一个动态编译。也就是一个脚本运行完后编译。

所以我这里应该是动态编译,因为外部Js文件在是一个blob对象,无法根据import,指定路径,运行时候在访问对应的Js文件。也就是这个路径是个虚拟的,无法真实找到的时候,不要用import。

vue如何识别import对象和require对象

  • require是CommonJs的语法(AMD规范引入方式),CommonJs的模块是对象。

  • import是es6的一个语法标准(浏览器不支持,本质是使用node中的babel将es6转码为es5再执行,import会被转码为require),es6模块不是对象

  • require是运行时加载整个模块(即模块中所有方法),生成一个对象,再从对象上读取它的方法(只有运行时才能得到这个对象,不能在编译时做到静态化),理论上可以用在代码的任何地方

  • import是编译时调用,确定模块的依赖关系,输入变量(es6模块不是对象,而是通过export命令指定输出代码,再通过import输入,只加载import中导的方法,其他方法不加载),import具有提升效果,会提升到模块的头部(编译时执行)

  • exportimport可以位于模块中的任何位置,但是必须是在模块顶层,如果在其他作用域内,会报错

这算解决了一个问题,可是component的Is属性时可以识别require和import对象,我直接丢进去,可是还是不行。

然后注意到一个点,VUE的生命周期!

然后发现我实在mounted导入的对象。。。。。。

提醒一下自己和看到的人,请不要在mounteds使用require和import,我改到created里面执行函数就可以。理论来说beforeCreated和beforeMounted也可以使用。未尝试过。

还有提醒一下,思考一个问题,不要钻牛角尖,换个思路,说不定豁然开朗,就像我这个问题。其实主要问题就是,导入对象的时期和导入的方法选择,而不是渲染。

component组件嵌套,导致页面重复渲染,重复请求的bug

因详情页面,有多个tab选项卡考虑页面多处重复使用,而且有多个页面组成,最终决定使用 组件方式来引用页面。

因 项目采用的UI组件是 element-ui,刚好看到有一个 样式很类似于 tab选项卡,就采用了 element的 tabs组件,可是 没想到问题就是出现 这儿。

如何解决vue的component标签渲染问题

错误代码

<el-tabs class="header-tabs" v-model="activeName" @tab-click="handleClick">   <el-tab-pane     v-for="item of tabs"     :key="item.id"     :label="item.label"     :name="item.id"     :component="item.component"     lazy     >      <keep-alive exclude="ContentManage">          <component :is="currentComponent" :customeroid="agencyid"></component>      </keep-alive>     </el-tab-pane></el-tabs>

因为上述采用了 tabs选项卡,而且也使用 v-for循环(没办法,主要是 tabs是动态的),导致 每个页面不仅没有办法 缓存,反而 一直重复发送请求。自己百度了好久,最后没办法寻求帮助,在大佬们 远程帮助下 最终发现的是 tabs下的 v-for导致。

因为 component 写在v-for循环中,每次循环都会 创建一个 对象,导致创建很多的组件,点击一次tabs 循环后的 所有的 component都 发送了请求,每次点击一次后,都会减少一次请求(因为 keep-alive缓存的问题)。

最终解决的方法,不在 element-ui的 tabs组件,自己手写页面,反正样式不复杂。

正确代码

<ul class="tabs-ul">    <li        v-for="(item) in currentTabs"        :key="item.id"        :class="{ active: tabSelect === item.id }"        @click.prevent="changetabs(item.id)"        >        {{ item.label }}    </li></ul><keep-alive exclude="ContentManage">    <component :is="currentComponent" :customeroid="agencyid"></component></keep-alive>

这样的就可以避免创建多个组件,从而不在出现 重复发送请求的bug。

感谢你能够认真阅读完这篇文章,希望小编分享的“如何解决vue的component标签渲染问题”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何解决vue的component标签渲染问题

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何解决vue的component标签渲染问题

这篇文章主要介绍了如何解决vue的component标签渲染问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。component标签渲染问题最近遇到一个问题,就是通过Load
2023-06-29

react异步渲染问题如何解决

在React中,异步渲染通常可以通过以下方式解决:1. 使用React.lazy和Suspense:React.lazy函数允许您在组件渲染时动态地导入一个组件。Suspense组件可以在加载组件时显示一个占位符,并处理加载过程中的错误。示
2023-09-04

Vue的异步渲染axios问题怎么解决

本文小编为大家详细介绍“Vue的异步渲染axios问题怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue的异步渲染axios问题怎么解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。Vue异步渲染ax
2023-07-05

vue3如何使用defineAsyncComponent与component标签实现动态渲染组件

本篇内容介绍了“vue3如何使用defineAsyncComponent与component标签实现动态渲染组件”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅
2023-07-06

echarts第二次的渲染问题如何解决

要解决echarts第二次的渲染问题,可以尝试以下方法:1. 销毁之前的实例:在进行第二次渲染之前,先调用echarts实例的dispose()方法进行销毁,然后再进行第二次的渲染。```javascriptmyChart.dispose(
2023-10-08

如何解决v-html渲染组件问题

这篇文章主要介绍如何解决v-html渲染组件问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!由于前面对html进行过解析,今天想用vue拖拽,实现一手类似快站那种自动生成代码,结果就遇到了拖拽组件过去怎么无法解析的
2023-06-15

解决vue组件渲染没更新数据问题

本文主要介绍了解决vue组件渲染没更新数据问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-02-09

vue修改数据页面不重新渲染问题如何解决

本文小编为大家详细介绍“vue修改数据页面不重新渲染问题如何解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue修改数据页面不重新渲染问题如何解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。vue渲染机制
2023-07-05

解决react组件渲染两次的问题

这篇文章主要介绍了解决react组件渲染两次的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-11-13

解决vue修改数据页面不重新渲染问题

这篇文章详细介绍了vue渲染机制和如何解决数据修改页面不刷新问题的多种方法,想了解更多的小伙伴可以借鉴阅读
2023-03-24

如何解决uniapp拿到数据不渲染页面问题

在移动端应用开发中,uniapp以其跨平台特性和高效开发方式,越来越受到广大开发者的关注和青睐。但是,在使用uniapp开发应用时,有时候我们会遇到拿到数据但是无法渲染页面的情况。下面就让我们一起来看看这种情况的解决方法。一、检查数据格式uniapp可以使用vue.js的数据绑定技术来实现页面渲染,但是在使用数据绑定时,需要保证数据格式正确,否则无法渲染页面。比如,如果我们使用
2023-05-14

如何通过php函数解决页面渲染慢的问题?

在开发网页应用的过程中,页面渲染慢是一个常见的问题。用户访问一个网页时,如果页面渲染时间过长,可能会导致用户的不耐烦,甚至放弃访问。因此,加快页面渲染速度对于提高用户体验和页面性能至关重要。PHP 是一种广泛使用的服务器端编程语言,它拥有丰
2023-10-21

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录