位置: IT常识 - 正文

Vue动态组件 component :is的使用(vue动态组件component原理)

编辑:rootadmin
Vue动态组件 component :is的使用

推荐整理分享Vue动态组件 component :is的使用(vue动态组件component原理),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue动态组件component如何调用方法,vue动态组件component,vue动态组件component,vue动态组件component is属性,vue动态组件component传值,vue动态组件component原理,vue动态组件component,vue动态组件component,内容如对您有帮助,希望把文章链接给更多的朋友!

vue 动态组件用于实现在指定位置上,动态加载不同的组件,核心代码为:

<component :is="componentTag"></component>data() { return { componentTag: '', }}

componentTag 为自定义的变量,将需要加载的组件名赋值给它,即可在<component />标签出现的位置,渲染该组件。

代码示范<template> <div style="padding: 30px"> <button @click="change('1')">组件1</button> <button @click="change('2')">组件2</button> <button @click="change('3')">组件3</button> <component :is="componentTag"></component> </div></template><script> import component1 from './component1' import component2 from './component2' import component3 from './component3' export default { components: {component1, component2, component3}, data() { return { componentTag: '', } }, methods: { change(index) { this.componentTag = 'component' + index }, } }</script><style scoped></style>

src/page/component1.vue

<template> <div> <h3>组件1—文字</h3> <span>我爱你,中国!</span> </div></template><script> export default { name: "component1" }</script><style scoped></style>

src/page/component2.vue

<template> <div> <h3>组件2-图片</h3> <img src="https://www.yuucn.com/wp-content/uploads/2022/03/1648645331-ccb34a595cb926f.png" alt=""> </div></template><script> export default { name: "component2" }</script><style scoped></style>

src/page/component3.vue

<template> <div> <h3>组件3—输入框</h3> <input type="text"> </div></template><script> export default { name: "component3" }</script><style scoped></style>效果展示点击按钮组件1

点击按钮组件2Vue动态组件 component :is的使用(vue动态组件component原理)

点击按钮组件3

以上原文链接:vue 动态组件【详解】component :is_朝阳39的博客-CSDN博客_component is

 component :is用法进阶之组件内引入多个组件<component :is="detailComponentName" />import components from './components'export default { components: { ...components }}

src/components/index.js

const ctx = require.context('./common', false, /\.vue$/)const components = {}console.log(ctx, 'ctx---打印出./common文件下(不包含子文件夹),以.vue结尾的文件')console.log( ctx.keys(), 'ctx.keys()---返回./common文件下(不包含子文件夹),以.vue结尾的文件的数组')for (const key of ctx.keys()) { // 剥去文件名开头的 `./` 和`.vue`结尾的扩展名 const module = key.replace(/^\.\//, '').replace(/\.vue$/, '') components[module] = ctx(key).default console.log(module, 'module---去掉`./`开头 和`.vue`结尾后的文件名') console.log( components[module], 'components[module]---拿到ctx文件(包括html和default)' )}console.log(components, 'components---这些ctx文件集合')export default components

此处解释该index.js文件:

require.context( directory, useSubdirectories, regExp )

directory{String}-读取文件的路径。useSubdirectories{Boolean}-是否遍历文件的子目录。regExp{RegExp}-匹配文件的正则。

require.context('./', false, /\.vue$/) 检索components文件下的文件,不检索子文件夹,匹配以.vue结尾的文件。

 

 

本文链接地址:https://www.jiuchutong.com/zhishi/295679.html 转载请保留说明!

上一篇:分配股利在报表哪里体现(分配股利账务处理)

下一篇:web前端面试高频考点——Vue的高级特性(动态组件、异步加载、keep-alive、mixin、Vuex、Vue-Router)(web前端面试题最新)

  • 企业微博营销的8种常见模式(企业微博营销的日常运营工作三部分)

  • java mybatis(java mybatis返回精度问题)

  • 18款和19款的macbook区别(18款和19款的奥德赛导航通用吗)

  • 果师兄没有恢复成功会退款吗(果师兄恢复一次多少钱)

  • 退货天猫购物券退吗(天猫购物券退款后券退到哪里去了)

  • 目前没有安装描述文件是什么意思(目前没有安装描述文件怎么安装软件)

  • 微信如何设置离线状态(微信如何设置离开状态)

  • iphone相机选高效还是兼容(iphone 相机 高效)

  • 三星折叠手机是5g的吗(三星折叠手机是哪里生产的)

  • vcf是什么(石油vcf是什么)

  • 小米智能插座增强版和zigbee区别(小米智能插座增强版电压过高)

  • 苹果8plus分屏功能在哪(苹果8plus分屏功能怎么用)

  • 手机电筒可以开通宵吗(手机电筒可以开一整晚吗)

  • 荣耀手环5和5i区别(荣耀手环5和5i哪个更值得入手)

  • 苹果8p处理器型号(苹果手机8p处理器)

  • 手机打不开流量怎么回事(苹果手机打不开流量)

  • 苹果x怎么录视频全屏(苹果x怎么录视频带声音)

  • 如何开通华为移动服务(怎么开通华为)

  • iphone激活时远程管理(苹果激活的时候远程管理是什么意思)

  • 小米一元流量在哪里开(小米一元流量在火车上卡吗)

  • 网页显示太大怎么修改(可以用马齿苋敷脸吗)

  • qq音乐财富等级在哪里(qq音乐财富等级充值表)

  • mac截图格式如何更改?修改Mac屏幕快照格式的方法介绍(mac截图如何保存到照片)

  • 2023跨年烟花(浪漫烟花+美妙音乐+雪花飘飘)含前端源码直接下载---系列最终篇(2023跨年烟花链接)

  • python如何实现图像等比缩放(python的图)

  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设 电脑维修 湖南楚通运网络