- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章vue3.0实现插件封装由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
最近公司有一个新的项目,项目框架是我来负责搭建的,所以果断选择了Vue3.x+ts。vue3.x不同于vue2.x,他们两的插件封装方式完全不一样。由于项目中需要用到自定义提示框,所以想着自己封装一个。vue2.x提供了一个vue.extend的全局方法。那么vue3.x是不是也会提供什么方法呢?果然从vue3.x源码中还是找到了。插件封装的方法,还是分为两步.
按照vue3.x的组件风格封装一个自定义提示框组件。在props属性中定义好。需要传入的数据流.
1
2
3
4
5
6
7
8
9
10
11
12
|
<
template
>
<
div
v-show
=
"visible"
class
=
"model-container"
>
<
div
class
=
"custom-confirm"
>
<
div
class
=
"custom-confirm-header"
>{{ title }}</
div
>
<
div
class
=
"custom-confirm-body"
v-html
=
"content"
></
div
>
<
div
class
=
"custom-confirm-footer"
>
<
Button
@
click
=
"handleOk"
>{{ okText }}</
Button
>
<
Button
@
click
=
"handleCancel"
>{{ cancelText }}</
Button
>
</
div
>
</
div
>
</
div
>
</
template
>
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
<script lang=
"ts"
>
import { defineComponent, watch, reactive, onMounted, onUnmounted, toRefs } from
"vue"
;
export
default
defineComponent({
name:
"ElMessage"
,
props: {
title: {
type: String,
default
:
""
,
},
content: {
type: String,
default
:
""
,
},
okText: {
type: String,
default
:
"确定"
,
},
cancelText: {
type: String,
default
:
"取消"
,
},
ok: {
type: Function,
},
cancel: {
type: Function,
},
},
setup(props, context) {
const state = reactive({
visible:
false
,
});
function
handleCancel() {
state.visible =
false
;
props.cancel && props.cancel();
}
function
handleOk() {
state.visible =
false
;
props.ok && props.ok();
}
return
{
...toRefs(state),
handleOk,
handleCancel,
};
},
});
</script>
|
这个才是插件封装的重点。不过代码量非常少,只有那么核心的几行。主要是调用了vue3.x中的createVNode创建虚拟节点,然后调用render方法将虚拟节点渲染成真实节点。并挂在到真实节点上。本质上就是vue3.x源码中的mount操作.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
import { createVNode, render } from
'vue'
;
import type {App} from
"vue"
;
import MessageConstructor from
'./index.vue'
const body=document.body;
const Message: any=
function
(options:any){
const modelDom=body.querySelector(`.container_message`)
if
(modelDom){
body.removeChild(modelDom)
}
options.visible=
true
;
const container = document.createElement(
'div'
)
container.className = `container_message`
//创建虚拟节点
const vm = createVNode(
MessageConstructor,
options,
)
//渲染虚拟节点
render(vm, container)
document.body.appendChild(container);
}
export
default
{
//组件祖册
install(app: App): void {
app.config.globalProperties.$message = Message
}
}
|
插件封装完整地址。源码位置————packages/runtime-core/src/apiCreateApp中的createAppAPI函数中的mount方法.
以上就是vue3.0实现插件封装的详细内容,更多关于vue 插件封装的资料请关注我其它相关文章! 。
原文链接:https://juejin.cn/post/6905409280761921543 。
最后此篇关于vue3.0实现插件封装的文章就讲到这里了,如果你想了解更多关于vue3.0实现插件封装的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我需要使用封装打印3个变量,并且无法修改主类。 主类声明变量[汽缸、制造商、所有者],并希望使用如下参数创建和打印一个对象: System.out.println (new Vehicle (cyli
我正在研究“Beginning Ruby”这本书,在我进行封装之前一切都进行得很顺利。我明白这段代码在做什么,我只是不知道为什么要用这些方法设置它。 对于那些感兴趣的人 this is the lin
所以我一直在研究面向对象的完整开发 JavaScript 实践,并对以下示例感到好奇。 据我了解,(这对我来说很有意义)以下“ secret ”字段是“私有(private)”的: var MyObj
在面向对象程式设计方法中,封装(英语:Encapsulation)是指,一种将抽象性函式接口的实作细节部份包装、隐藏起来的方法。 封装可以被认为是一个保护屏障,防止该类的代码和数据被外部类定义的代
封装 被定义为 把一个或多个项目封闭在一个物理的或者逻辑的包中 。在面向对象程序设计方法论中,封装是为了防止对实现细节的访问。 抽象和封装是面向对象程序设计的相关特性。抽象允许相关信息可
今天我读了一本书,作者写道,在一个设计良好的类中,访问属性的唯一方法是通过其中一个类方法。这是一个被广泛接受的想法吗?为什么封装属性如此重要?不做会有什么后果?我早些时候在某处读到这可以提高安全性或类
今天我接受了软件工程职位的面试。我已经从 stackoverflow 中阅读了很多关于面试的内容。他们向我询问了与 OOP 相关的正常情况。但他们也问我这些: 没有继承就可以封装吗? 没有继承就可以抽
我正在制作一个简单的网站,并编写了gradle构建脚本,该脚本将执行诸如lint并最小化css / html / js之类的事情。 在这一阶段,我刚刚完成了正在运行的CSS,但是只是初始的非结构化格式
下面的幻灯片是指 C++ 语言,它说 "encapsulation is about ensuring the user uses our ADT in a safe way" 但是,如果他可以访问我
尝试设置一个 Person 类 我在尝试将信息封装在类中以使其不会被意外更改时遇到了问题。除了当我尝试使用 setter/getters 进行封装时,该类工作得非常好。我认为问题是这些方法最终会互相循
面向对象的概念:封装、数据抽象和数据隐藏是3个不同的概念,但彼此之间非常相关。所以我很难通过阅读互联网上的信息来完全理解这些概念。一个地方可用的信息与互联网上另一个地方的信息相矛盾。有人可以指导我阅读
我被封装困住了。在我看来,好像我已经按照规则做了一切,但仍然不起作用。虽然我知道我错过了一些东西。我正在使用 Eclipse。 我想要通过创建一副标准 52 张卡片来进行一些练习,并尝试我学到的新东西
在java中,要获取映射中的所有键,我们可以使用方法keySet。但我想知道为什么方法名称不只是 keys ?名称 Set 是否会泄露有关实现的详细信息? 据我了解,Java 是静态类型语言,名称中包
我正在尝试找出如何防止应用程序中的页面变量被全局定义。我想出了一些方法,但我想知道是否有人们使用的通用标准方法。 我使用这种方法得到了我的插件设计模式:http://www.virgentech.co
我有一个 tcp 连接,我想在服务器类的 HandleConnectionAsync 方法中保持打开状态。它将从客户端接收持续更新。 private async void HandleConnecti
这是我类(class)的一个小样本: #include #include using std::string; using std::vector; struct Book { string
我想要类似下面的代码: class Foo{ public: void update() { for( auto dataModifier : _dataModifierLis
这已经困扰我一段时间了,所以我问了一个同事他是否能理解它,现在我来了;) 为什么可以在依赖属性的 PropertyChangedCallback 中访问持有类的私有(private)成员? 让我通过这
我知道封装意味着一个对象不应该直接访问不同对象的成员……但我猜它与公共(public)领域有关?我假设公共(public)方法不会破坏封装..?我只是在这里不清楚,很高兴得到任何解释。 最佳答案
我就废话不多说了,大家还是直接看代码吧~ ? 1
我是一名优秀的程序员,十分优秀!