91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在vue中創建組件

發布時間:2020-12-31 15:06:53 來源:億速云 閱讀:132 作者:Leah 欄目:開發技術

怎么在vue中創建組件?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

Vue動態創建組件實例并掛載到body

方式一

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
}

方式二

import Vue from 'vue'

export function create(Component, props) {
 // 借雞生蛋new Vue({render() {}}),在render中把Component作為根組件
 const vm = new Vue({
  // h是createElement函數,它可以返回虛擬dom
  render(h) {
   console.log(h(Component,{ props }));
   
   // 將Component作為根組件渲染出來
   // h(標簽名稱或組件配置對象,傳遞屬性、事件等,孩子元素)
   return h(Component, { props })
  }
 }).$mount() // 掛載是為了把虛擬dom變成真實dom
 // 不掛載就沒有真實dom
 // 手動追加至body
 // 掛載之后$el可以訪問到真實dom
 document.body.appendChild(vm.$el)

 console.log(vm.$children);
 
 // 實例
 const comp = vm.$children[0]

 // 淘汰機制
 comp.remove = () => {
  // 刪除dom
  document.body.removeChild(vm.$el)

  // 銷毀組件
  vm.$destroy()
 }

 // 返回Component組件實例
 return comp
}

使用

A組件(要動態創建的組件)

<template>
 <div class="a">
  <h3>{{ title }}</h3>
  <p>{{ data }}</p>
 </div>
</template>

<script>
export default {
 props: {
  title: {
   type: String,
   default: "hello world!"
  },
  message: {
   type: String,
   default: "o(∩_∩)o 哈哈"
  },
  duration: {
   type: Number,
   default: 1000
  }
 },
 data() {
  return {
   data: "我是a組件",
  };
 },
 created() {
  let num = 1
  
  const timer = setInterval(() => {
   this.data = num++
  }, this.duration)

  this.$once("hook: beforeDestroy", () => clearInterval(timer))
 }
};
</script>

<style>
.a {
 position: fixed;
 width: 100%;
 top: 16px;
 left: 0;
 text-align: center;
 pointer-events: none;
 background-color: #fff;
 border: grey 3px solid;
 box-sizing: border-box;
}
</style>

B組件(操作動態創建組件的地方)

<template>
 <div class="b">
  <button @click="createA">創建</button>
 </div>
</template>

<script>
import A from "@/components/A.vue"
import { create } from "@/utils/create.js"
export default {

 components: {
  A,
 },
 methods: {
  createA() {
   // 創建A組件,并掛載到body上
   create(A, { title: "vue", message: "" })
  }
 },
};
</script>

看完上述內容,你們掌握怎么在vue中創建組件的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

永吉县| 武平县| 和政县| 山阴县| 阳城县| 闻喜县| 班玛县| 沙坪坝区| 聊城市| 高青县| 常宁市| 霍林郭勒市| 会理县| 门源| 丰原市| 调兵山市| 正安县| 庄浪县| 鸡西市| 宜黄县| 濮阳市| 惠来县| 永靖县| 波密县| 玉树县| 遵义县| 遵义市| 萍乡市| 吉林省| 盐山县| 临夏县| 宣恩县| 桦川县| 旬邑县| 桑植县| 监利县| 南京市| 临夏市| 鹤峰县| 阿图什市| 罗江县|