日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

vue3+ts+elementPLus實現v-preview指令

瀏覽:240日期:2022-06-09 18:26:21
目錄
  • 引文
  • 目錄
  • 文件內容
    • previewImage.vue
    • preview.ts
  • 使用
    • 開發中可能遇到的問題
      • 總結

        引文

        最近在用 vue3+ts 開發公司的后臺系統,因為后臺多處需要圖片放大預覽的功能,就想著封裝一個v-preview指令,這樣在需要預覽的圖片上加個 v-preview就可以預覽啦。

        目錄

        在這里就不列我的項目目錄啦,想嘗試的朋友可以這樣創建目錄

        -- preview
        ---- previewImage.vue
        ---- preview.ts

        文件內容

        previewImage.vue

        普普通通vue3組件,記得全局注冊

        <template>
        ? ? <div @click="dialogVisible = true">
        ? ? ? ? <slot>
        ? ? ? ? ? ? <img :src="props.src" />
        ? ? ? ? </slot>
        ? ? </div>
        ? ? <el-dialog v-model="dialogVisible" title="查看圖片" @close="close">
        ? ? ? ? <img :src="imgSrc" />
        ? ? </el-dialog>
        </template>
        <script setup lang="ts">
        ? ? import { ref, getCurrentInstance, ComponentInternalInstance, onMounted } from "vue"
        ? ? import { ElDialog } from "element-plus"
        ? ? const props = defineProps({
        ? ? ? ? src: String
        ? ? })
        ? ? const dialogVisible = ref(false)
        ? ? const imgSrc = ref("")
        ? ? // 插槽形式
        ? ? onMounted(() => {
        ? ? ? ? const { proxy } = getCurrentInstance() as ComponentInternalInstance
        ? ? ? ? let slot = proxy?.$slots?.default?.()
        ? ? ? ? if(slot){
        ? ? ? ? ? ? // 獲取插槽內容設置imgSrc地址
        ? ? ? ? ? ? imgSrc.value = slot?.[0]?.props?.src
        ? ? ? ? }
        ? ? })
        ? ? const setSrc = (v: string) => {
        ? ? ? ? imgSrc.value = v
        ? ? }
        ? ? // 組件觸發
        ? ? if (props.src) {
        ? ? ? ? setSrc(props.src)
        ? ? }
        ? ? // 指令觸發
        ? ? const show = () => {
        ? ? ? ? dialogVisible.value = true
        ? ? }
        ? ? const close = () => {?
        ? ? ? ? // 彈窗關閉移除dom
        ? ? ? ? if (document.getElementById("previewDom")) {
        ? ? ? ? ? ? document.body.removeChild(document.getElementById("previewDom") as HTMLElement)
        ? ? ? ? }
        ? ? }
        ? ? defineExpose({
        ? ? ? ? show,
        ? ? ? ? setSrc
        ? ? })
        </script>

        preview.ts

        對previewImage組件進行拓展,全局注冊preview指令(這個注冊代碼就不放了呦)
        需要注意的是vue3拓展組件和vue2有所不同,vue2用Vue.extend就可以拿到組件構造器,vue3這邊則是使用createApp

        import { Component, createApp } from "vue"
        import PreviewImageVue from "@/components/PreviewImage.vue"
        function mountComponent(RootComponent: Component) {
        ? ? const app = createApp(RootComponent)
        ? ? const root = document.createElement("div")
        ? ? root.setAttribute("id", "previewDom")
        ? ? document.body.appendChild(root)
        ? ? return {
        ? ? ? ? instance: app.mount(root),
        ? ? ? ? unmount() { // 這里unmout沒用到,因為組件中dialog的close事件這里監聽不到,我就在組件內進行卸載了
        ? ? ? ? ? ? console.log("unmount")
        ? ? ? ? ? ? document.body.removeChild(root)
        ? ? ? ? }
        ? ? }
        }
        const preview = {
        ? ? mounted(el: any) {
        ? ? ? ? el.style.cursor = "zoom-in"
        ? ? ? ? el.addEventListener("click", () => {
        ? ? ? ? ? ? let imgSrc = el.getAttribute("src")
        ? ? ? ? ? ? let { instance, unmount } = mountComponent(PreviewImageVue)
        ? ? ? ? ? ? ;(instance as any).setSrc(imgSrc)
        ? ? ? ? ? ? ;(instance as any).show()
        ? ? ? ? })
        ? ? }
        }
        export default preview

        使用

        本地資源測試

        <div>
        ? ? <!-- 普通圖片 -->
        ? ? <img src="~@/assets/images/logo.png">
        ? ? <!-- 組件形式使用預覽組件、需要注意路徑(使用絕對路徑) -->
        ? ? <PreviewImage src="/src/assets/images/logo.png"></PreviewImage>
        ? ? <!-- 組件插槽形式預覽組件、需要注意路徑(使用絕對路徑) -->
        ? ? <PreviewImage>
        ? ? ? ? <img src="/src/assets/images/logo.png">
        ? ? </PreviewImage>
        ? ? <!-- 指令使用預覽組件 -->
        ? ? <img src="~@/assets/images/logo.png" v-preview>
        </div>

        開發中可能遇到的問題

        • 獲取proxy時使用getCurrentInstance時編輯器會報錯,斷言成ComponentInternalInstance就不報錯了。
        • 獲取插槽內容時需要 proxy?.$slots?.default?.() 這樣判斷取值,不然編輯器也會報錯。
        • 暴露給外部使用的方法/屬性需通過defineExpose暴露出去
        • 注意拓展組件方式。vue2用Vue.extend,vue3用createApp
        • 使用的時候注意路徑問題

        總結

        之前都是用vue2開發項目,此次項目是vue3的第一次實踐,使用下來感覺ts寫起來比較冗余,很多編輯器報錯都需要時間去解決,可能不是開發組件庫都是業務需求,對類型接口的定義使用很少。個人不是很喜歡ts,還是js來的簡單粗暴。

        到此這篇關于vue3+ts+elementPLus實現v-preview指令的文章就介紹到這了,更多相關vue3 v-preview指令內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

        標簽: JavaScript
        日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
        久久精品99国产精品| 亚洲aa在线| 日韩av一区二区三区四区| 日本综合精品一区| 日韩久久一区| 国产精品美女午夜爽爽| 成人看片网站| 久久福利精品| 日本一区免费网站| 国产精品一区二区av交换| 国产精品一级| 日韩精品不卡一区二区| 久久久久91| 自由日本语亚洲人高潮| 香蕉精品999视频一区二区| 91精品蜜臀一区二区三区在线 | 国产一区二区三区91| 成人午夜精品| 蜜臀久久久99精品久久久久久| 人人爱人人干婷婷丁香亚洲| 国产+成+人+亚洲欧洲在线| 91精品婷婷色在线观看| 三级欧美韩日大片在线看| 欧美日韩a区| 伊人久久国产| 亚洲精选av| 手机在线电影一区| 亚洲欧美日韩国产一区| 国产精品三级| 水蜜桃久久夜色精品一区| 99视频在线精品国自产拍免费观看| 欧美精品国产一区| 久久久精品午夜少妇| 亚洲精品自拍| 在线中文字幕播放| 综合激情五月婷婷| 美女福利一区二区三区| 日韩中文字幕| 久久久久亚洲| 亚洲午夜精品久久久久久app| 一区二区小说| 美日韩精品视频| 国产日韩亚洲| 99精品在线免费在线观看| 亚洲91视频| 婷婷成人av| 亚洲在线成人| 精品视频97| 亚洲久草在线| 免费污视频在线一区| 国产亚洲字幕| 好吊一区二区三区| 超碰在线99| 欧美日韩一区二区高清| 国产亚洲永久域名| 视频在线不卡免费观看| 日韩va亚洲va欧美va久久| 日韩毛片在线| 精品丝袜久久| 久久www成人_看片免费不卡| 三上亚洲一区二区| 国产欧美在线观看免费| 免费不卡在线视频| 成人国产综合| 国产欧美日韩一区二区三区四区| 精品欧美激情在线观看| 久久久精品国产**网站| 日本aⅴ亚洲精品中文乱码| 好吊视频一区二区三区四区| 97精品国产福利一区二区三区| 欧美视频精品全部免费观看| 国产亚洲一区在线| 欧美日韩一二三四| 超碰99在线| 国产精品一区三区在线观看| 视频一区中文字幕国产| 蜜桃视频欧美| 日韩精品欧美| 欧美香蕉视频| 国产96在线亚洲| 精品一级视频| 久久久精品国产**网站| 国产日韩一区| 国产欧美高清视频在线| 欧美一区不卡| 日韩精品视频网| 日本亚洲欧洲无免费码在线| 男女性色大片免费观看一区二区 | 天堂av在线| 91亚洲国产成人久久精品| 黄色网一区二区| 精品视频一二| 麻豆视频在线观看免费网站黄 | 精品久久国产一区| 欧美激情视频一区二区三区免费| 91精品蜜臀一区二区三区在线| 精品视频一二| 日韩成人精品一区二区三区 | 久久精品国产大片免费观看| 久久精品三级| 久久中文字幕一区二区| 国产精品任我爽爆在线播放| 视频一区中文字幕精品| 亚洲精品乱码日韩| 综合国产视频| 欧美午夜三级| 久久亚洲精精品中文字幕| 麻豆网站免费在线观看| 亚洲一本视频| 综合国产在线| 国产日产精品一区二区三区四区的观看方式| 国产一卡不卡| 国产videos久久| 99精品视频在线| 亚洲激情另类| 亚洲欧美久久精品| 国产精品天天看天天狠| 精品国产18久久久久久二百| 欧美精选视频一区二区| 久久xxxx| 蜜臀av性久久久久蜜臀aⅴ流畅| 丝袜诱惑制服诱惑色一区在线观看 | 蜜臀久久久久久久| 97久久超碰| 国产在线观看www| 午夜电影亚洲| 久久狠狠久久| 精品捆绑调教一区二区三区| 免费日韩av片| 国产精品亚洲综合色区韩国| 黄色aa久久| 国产亚洲午夜| 国产欧美日韩免费观看| 成人日韩精品| 日本综合精品一区| 97视频热人人精品免费| 午夜在线精品| 国产精品红桃| 91九色精品| 国产精品九九| 91久久黄色| 美女视频一区在线观看| 久久中文字幕av一区二区不卡| 中文字幕成人| 蜜桃av.网站在线观看| 色婷婷成人网| 久久久一本精品| 欧美亚洲免费| 激情综合网站| 免费一级欧美在线观看视频| 伊人精品视频| 精品亚洲a∨| 免播放器亚洲| 中文字幕在线官网| 日本va欧美va瓶| 国产在线不卡| 精品久久久中文字幕| 美女国产精品| 97精品一区二区| 欧美一级二区| 六月丁香综合| 久久久久一区| 麻豆久久久久久| 少妇精品在线| 免费久久久久久久久| 久久亚洲人体| 日韩高清电影一区| 久久亚洲专区| 卡一卡二国产精品| 亚洲精品成a人ⅴ香蕉片| 国产综合精品| 久草免费在线视频| 宅男在线一区| 亚洲欧美高清| 日韩影院免费视频| 日韩欧美午夜| 你懂的国产精品| 亚洲精品一级| japanese国产精品| 中文字幕在线高清| 国产精品美女在线观看直播| 午夜在线精品偷拍| 麻豆91精品视频| 日韩中文一区二区| 亚洲综合专区| 视频一区在线视频| 日韩午夜一区| 激情综合网站| 亚洲午夜久久久久久尤物| 9999国产精品| 精品美女久久| 精品国产亚洲一区二区三区在线 | 日日夜夜免费精品视频| 999国产精品999久久久久久| 久久久久伊人| 日欧美一区二区| 五月婷婷亚洲| 在线一区免费| 激情综合自拍| 99热国内精品|