## :-: Vue 全局挂载组件的通用方法
:-: @/plugins/create.js
```
import Vue from 'vue'
/*
* Vue 全局挂载组件的通用方法
* create(Component, props, callBack);
*/
export default function create(Component, props, callBack) {
// 创建实例
const vm = new Vue({
render(h) {
// h为createElement,返回VNode虚拟Node
return h(Component, { props });
}
}).$mount();
// 手动挂载实例到body
document.body.appendChild(vm.$el);
const comp = vm.$children[0];
// 销毁方法
comp.$remove = function (data) {
document.body.removeChild(vm.$el);
vm.$destroy();
typeof callBack === 'function' && callBack('close', data);
}
// 返回组件
return comp;
}
```
:-: @/main.js
```
import create from "@/plugins/create.js"
Vue.prototype.$create = create; // Vue全局挂载组件的通用方法、
```
:-: @/components/E-alert.js
```
// 提供一个退出的方法 (其他的跟普通组件一样)
methods: {
close(data) {
// 调用销毁组件的方法 (自动判断是静态/动态调用,进行不同的处理)
this.$remove ? this.$remove(data) : this.$emit("close", data);
}
}
```
:-: @/App.vue
```
import EAlert from "@/components/E-alert.vue";
export default {
mounted() {
this.$create(
EAlert,
{ title: "温馨提示", content: "该Object会当做props传入组件" },
(type, data) => {
/*
* '动态'组件的调用函数
* type -- 类型(如close为销毁时触发的)、
* data -- '动态'组件返回的数据。
*/
console.log(data);
}
);
}
}
```
- 前端工具库
- HTML
- CSS
- 实用样式
- JavaScript
- 模拟运动
- 深入数组扩展
- JavaScript_补充
- jQuery
- 自定义插件
- 网络 · 后端请求
- css3.0 - 2019-2-28
- 选择器
- 边界样式
- text 字体系列
- 盒子模型
- 动图效果
- 其他
- less - 用法
- scss - 用法 2019-9-26
- HTML5 - 2019-3-21
- canvas - 画布
- SVG - 矢量图
- 多媒体类
- H5 - 其他
- webpack - 自动化构建
- webpack - 起步
- webpack -- 环境配置
- gulp
- ES6 - 2019-4-21
- HTML5补充 - 2019-6-30
- 微信小程序 2019-7-8
- 全局配置
- 页面配置
- 组件生命周期
- 自定义组件 - 2019-7-14
- Git 基本操作 - 2019-7-16
- vue框架 - 2019-7-17
- 基本使用 - 2019-7-18
- 自定义功能 - 2019-7-20
- 自定义组件 - 2019-7-22
- 脚手架的使用 - 2019-7-25
- vue - 终端常用命令
- Vue Router - 路由 (基础)
- Vue Router - 路由 (高级)
- 路由插件配置 - 2019-7-29
- 路由 - 一个实例
- VUEX_数据仓库 - 2019-8-2
- Vue CLI 项目配置 - 2019-8-5
- 单元测试 - 2019-8-6
- 挂载全局组件 - 2019-11-14
- React框架
- React基本使用
- React - 组件化 2019-8-25
- React - 组件间交互 2019-8-26
- React - setState 2019-11-19
- React - slot 2019-11-19
- React - 生命周期 2019-8-26
- props属性校验 2019-11-26
- React - 路由 2019-8-28
- React - ref 2019-11-26
- React - Context 2019-11-27
- PureComponent - 性能优化 2019-11-27
- Render Props VS HOC 2019-11-27
- Portals - 插槽 2019-11-28
- React - Event 2019-11-29
- React - 渲染原理 2019-11-29
- Node.js
- 模块收纳
- dome
- nodejs - tsconfig.json
- TypeScript - 2020-3-5
- TypeScript - 基础 2020-3-6
- TypeScript - 进阶 2020-3-9
- Ordinary小助手
- uni-app
- 高德地图api
- mysql
- EVENTS
- 笔记
- 关于小程序工具方法封装
- Tool/basics
- Tool/web
- parsedUrl
- request