如果把vue组件动态添加到body上?

tools.js:

javascript 复制代码
import Vue from 'vue'
 
/**
 * @param Component 组件实例的选项对象
 * @param props 组件实例中的prop
 */
export function create(Component, props) {
  const comp = new (Vue.extend(Component))({ propsData: props }).$mount()
   
  document.body.appendChild(comp.$el)
 
  comp.remove = () => {
    document.body.removeChild(comp.$el)
 
    comp.$destroy()
  }
 
  return comp
}

App.js:

javascript 复制代码
<template>
  <div class="m-feedback-out-wrap">
    <el-button @click="handleAdd">添加</el-button>
  </div>
</template>

<script>
import { Feedback } from './feedback'
import { Button } from 'element-ui'
import { create } from './tools'
import './index.css'

let feeback
export default {
  name: 'App',
  data() {
    return {}
  },
  components: {
    [Button.name]: Button,
    Feedback,
  },
  mounted() {
    this.handleAdd()
  },
  methods: {
    handleAdd() {
      if (feeback) {
        feeback.remove()
      }
      feeback = create(Feedback)
    },
    handleInit() {
      let node = document.getElementById('m-feedback')
      if (node) {
        node.parentNode.removeChild(node)
      }
      let newElement = document.createElement('div')
      newElement.id = 'm-feedback'
      newElement.innerHTML = 'Hello World'
      document.body.appendChild(newElement)
    },
  },
}
</script>

我开发的chatgpt项目:

https://chat.xutongbao.top/

相关推荐
ct97825 分钟前
Three.js 性能优化(测量-定位-优化)
javascript·性能优化·three
研☆香26 分钟前
es6新特性功能介绍(一)
前端·ecmascript·es6
陈_杨37 分钟前
鸿蒙开发-疾阅App阅读训练功能技术解析
前端·javascript
不好听6131 小时前
Node.js 工程化开发流程 — 知识点总结
javascript·node.js
ZengLiangYi1 小时前
sql.js WASM 深度解析
javascript·数据库·后端
JustHappy2 小时前
古法编程秘籍(三):为什么需要函数?因为程序员讨厌重复劳动
前端·javascript·后端
一 乐2 小时前
人口老龄化社区服务与管理平台|基于springboot+vue的人口老龄化社区服务与管理平台(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·人口老龄化社区服务与管理平台
想要狠赚笔的小燕2 小时前
vue项目的入口文件是什么 main.js还是index.html,他俩有啥区别
前端·javascript
之歆2 小时前
Day02_ES6+ 核心特性深度解析:现代 JavaScript 开发的基石
前端·javascript·es6
小KK_3 小时前
新手必看篇——JS类型判断
前端·javascript