Vue.extend()和我的两米大砍刀

embedded/2024/10/31 1:33:27/

Vue.extends是什么?

一个全局API,用于注册并挂载组件。
传统的引用组件的方式是使用import直接引入,但是使用Vue.extends()也可以实现。

使用规则

<div id="mount-point"></div>
// 创建构造器
var Profile = Vue.extend({template: '<p>{{firstName}} {{lastName}} aka {{alias}}</p>',data: function () {return {firstName: 'Walter',lastName: 'White',alias: 'Heisenberg'}}
})
// 创建 Profile 实例,并挂载到一个元素上。
new Profile().$mount('#mount-point')
//你可以挂载到任何你想挂载的地方
//new Profile().$mount("#app")

注意:应用场景

这种操作类似于直接用js操作dom元素,belike

//创建
const dom = document.createElemnet('div')
dom.innerHtml = '你好'
//挂载
const container = document.getElementById('#mount-point')
container.appendChild(container)

通过这样的类比,我们很容易就明白为什么不推荐使用这种方式去引入使用一个模块组件,因为vue是有自己的虚拟DOM机制和组件挂载过程的,所以不推荐直接操作DOM。建议还是通过触发数据的变化,引发视图变化,即MVVM机制。
非必要请不要使用这种方式去声明使用组件,因为它会使代码变得不好读,且容易造成误解。那么我们在什么情景下去使用这个api呢?

  • vue.extend主要用于动态创建组件的场景,比如弹窗组件、提示框组件等。(官网这么说,但我依然建议不要这么做。)
  • 组件模板都是事先定义好的,我要从接口动态渲染组件。

1.举个我在项目中使用的实际场景:弹窗组件、提示框组件

function createModal(options) {const Modal = Vue.extend({data() {return {title: options.title,content: options.content};},template: `<div class="modal"><h2>{{ title }}</h2>{{ content }}</div>`});const modal = new Modal();modal.mount();document.body.appendChild(modal.el);
}// 调用createModal方法创建一个弹窗
createModal({title: '提示',content: '这是一个弹窗示例'
});

2.一些操蛋的思路:当时在做这个对话的时候我只想着在发生对话的时候创建一个dom,而非使用视图触发,后面涉及了一些复杂交互头痛。写在这里用于加深学习吧……
对话场景

//DialogueItem.vue<template>你好<div @click='stopCurrentAsk'>停止</div>
</template>
<script>
import Vue from 'vue'
export default {name: "DialogueItem ",props: ['type', 'content', 'id'],data() {return {loading: false,};},methods: {changeLoadingStatus(loading) {this.loading = loading},stopCurrentAsk(id) {this.$emit('stopAsk');},}
};
</script>
import DialogueItem from '@/components/DialogueItem'public instand = nullthis.instand = new (Vue.extend(DialogueItem))({propsData: { type, id, content },})this.instand.$mount()//1.子组件触发父组件事件。//上文也提到,这就是个封装成组件的dom,所以,想要通过子组件DialogueItem触发父组件的内容,就直接监听事件就行了this.instand.$on("stopAsk", () => {});//2.父组件触发子组件this.instand.changeLoadingStatus(false)dom.appendChild(this.instand.$el)

说实话,真的难用,大抵是我场景不对。但是用都用了记录一下。

关于我的两米大砍刀

我在项目开发中发现同样的引用和参数,却无法产生同样的结果,最后定位发现是两个组件不同的构建方式导致的。这个罪魁祸首就是Vue.extend(),换一种组件引入方式就解决了。
至于为什么,搜索了半天没有明白是什么原因,有的说是vuex没有被正确注入到根实例中。
懒得看了,反正子组件无法使用vuex,也无法使用,谁知道可以来踩踩……
少用,谢谢!


http://www.ppmy.cn/embedded/9373.html

相关文章

BCLinux8U6系统部署oceanbase分布式数据库社区版之一、准备 OBD 中控机

本文记录了在BCLinux8U6操作系统的虚拟服务器准备oceanbase开源数据库的 OBD 中控机的过程。 一、中控机环境 1、虚拟服务器硬件配置 2、操作系统版本信息 [rootlocalhost ~]# cat /etc/os-release NAME"BigCloud Enterprise Linux" VERSION"8.6 (Core)&qu…

C语言实现链式队列

链式队列 有头结点&#xff0c;使得frontrear为判空条件 1、创建链式队列 typedef int data_type; typedef struct link_node{struct link_node *next;data_type data; }link_list; typedef struct{ link_list *front; link_list *rear; }link_queue;link_queue *create_lin…

SpringBoot整合Mybatis

目录 一、引入依赖 二、创建实体类 三、编写mapper接口以及映射文件 Mapper接口 映射文件 四、编写application.yml配置文件 五、进行测试 之前搭建项目的时候&#xff0c;没有什么问题包括引入依赖&#xff0c;结果在测试的时候一直报错&#xff0c;后面原因竟然是引入…

学习 Rust 的第七天:如何理解引用

大家好&#xff0c; 今天是我学 Rust 的第7天&#xff0c;今天我要来看一下引用和借用。昨天我学习了 Rust 的所有权模型&#xff0c;如果你对 Rust 一无所知的话&#xff0c;那篇文章是必读的。 引用 昨天我们看到&#xff0c;将参数传递给函数与将值赋给另一个变量产生了相…

【任务调度】Apache DolphinScheduler快速入门

Apache DolphinScheduler基本概念 概念&#xff1a;分布式、去中心化、易扩展的可视化DAG工作流任务调度系统。 作用&#xff1a;解决数据处理流程中错综复杂的依赖关系&#xff0c;使调度系统在数据处理流程中开箱即用。Apache DolphinScheduler是一款开源的调度工具&#xff…

声明式事务

文章目录 1.事务分类1.传统方式解决事务2.声明式事务 2.声明式事务案例1.需求分析2.解决方案分析3.数据表创建4.编写GoodsDao.java1.编写配置文件JdbcTemplate_ioc.xml2.单元测试 5.编写GoodsService.java6.配置事务管理器JdbcTemplate_ioc.xml7.进行测试 3.debug事务管理器Dat…

大模型日报2024-04-22

大模型日报 2024-04-22 大模型资讯 Mistral与Mixtral大型语言模型对比&#xff1a;7B、8x7B及8x22B 摘要: 最近&#xff0c;IT新闻频道广泛报道了新公开的Mixtral 8x22B模型&#xff0c;该模型在多项基准测试中超越了ChatGPT 3.5版本&#xff0c;尤其在MMLU等测试中表现突出。本…

Python爬虫数据可视化分析

Python爬虫用于从网络上获取数据&#xff0c;数据可视化分析则是将获取的数据进行可视化展示和分析&#xff0c;帮助我们更好地理解数据、发现规律、做出决策。下面是一个基本的Python爬虫数据可视化分析的流程&#xff1a; 步骤一&#xff1a;数据爬取 1.选择合适的爬虫工具&a…