web面試vue自定義組件及調用方式
引入:
由於項目需求, 部分相同的代碼我們會封裝成組件, 在需要使用的地方導入,
並以標簽的形式書寫在中,
但是在”vant”組件庫中, “Dialog 彈出框”組件有2中使用方式
通常我們自定義組件, 一般也是通過方式二的形式使用, 今天介紹方式一如何使用
編碼實現
以插件的形式使用組件
// 將要顯示的組件導入 import mymodel from '../components/mymodel.vue' export default { install: function (Vue) { // 1.0 根據 mymodel 組件對象得到它的構造函數 const Mymodel = Vue.extend(mymodel) // 給所有的 vue 實例添加一個方法 $model Vue.prototype.$model = function () { // 為瞭顯示一個組件: mymodel // 2.0 創建一個組件對象 const obj = new Mymodel() // 3.0 將組件顯示出來 obj.show = true // 4.0 得到組件對象的 html 結構 const html = obj.$mount().$el // 5.0 將 html 結構渲染到頁面上 document.body.append(html) } } }
使用
<template> <div> <h3>以普通組件的方法來調用</h3> <button @click="fn1">show Model</button> <!-- <mymodel :value="show" @input="val => (show = val)"></mymodel> --> <mymodel v-model="show"></mymodel> <!-- sync:向組件內傳入瞭參數: xxx 從組件中接收瞭事件:update:xxx 事件會自動修改 xxx --> <!-- v-model:向組件內傳入瞭參數: value 從組件中接收瞭事件:input 事件會自動修改 value --> <h3>以 js 方式來調用</h3> <button @click="fn2">show Model</button> </div> </template> <script> import mymodel from '../../components/mymodel.vue' export default { data () { return { show: false } }, methods: { fn1 () { this.show = true }, fn2 () { // 通過 js 的方法直接將組件顯示出來 this.$model() } }, components: { mymodel: mymodel } } </script> <style></style>
以上就是web面試vue自定義組件及調用方式的詳細內容,更多關於web面試vue的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- 在vant中如何使用dialog彈窗
- vue在自定義組件上使用v-model和.sync的方法實例
- 詳解vue3.2中setup語法糖<script lang="ts" setup>
- vue修飾符v-model及.sync原理及區別詳解
- Vue3 SFC 和 TSX 方式自定義組件實現 v-model的詳細過程