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

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

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

瀏覽:243日期: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久久,三上悠亚国产精品一区二区三区
        国产一区二区久久久久| 亚洲色图网站| 亚洲一区观看| 在线视频免费在线观看一区二区| 欧美69视频| 日韩中文字幕麻豆| 日本成人一区二区| 久久精品理论片| 999久久久精品国产| 狠狠色综合网| 青青国产精品| 国产一区丝袜| 免费视频一区三区| 亚久久调教视频| 精品国产亚洲一区二区三区在线| 日韩视频网站在线观看| 亚洲欧洲另类| 男女性色大片免费观看一区二区 | 黄色成人精品网站| 男女男精品视频网| 国产精品永久| 成人看片网站| 日韩国产91| 麻豆精品蜜桃| 91精品国产自产在线丝袜啪| 久久男人av资源站| 久久国产精品亚洲77777| 欧美日本不卡| 久久网站免费观看| 日韩高清电影一区| 久久蜜桃精品| 日韩精品一级| 国产99精品| 欧美啪啪一区| 欧美女激情福利| 久久精品国产99国产| 妖精视频成人观看www| 国产欧美丝祙| 国产婷婷精品| 福利一区二区三区视频在线观看| 欧洲激情综合| 免费精品一区| 亚洲日本三级| 美女福利一区二区三区| 亚洲一区二区日韩| 成人在线免费观看91| 久久亚洲欧洲| 电影天堂国产精品| 国产精品一区二区三区av| 99国产精品| 波多视频一区| 国产精品porn| 亚洲精品日韩久久| 亚洲www啪成人一区二区| 欧美日本不卡高清| 最新日韩av| 不卡一二三区| 美女视频黄 久久| 日韩精品久久久久久久软件91| 欧美日韩在线二区| 精品一区不卡| 欧美午夜网站| 最近国产精品视频| 国产专区一区| www.九色在线| 日韩国产精品久久久| 亚洲欧美日韩国产综合精品二区| 久久99久久久精品欧美| 日本亚洲最大的色成网站www| 精品中文字幕一区二区三区av| 国产福利亚洲| 日韩精品亚洲一区二区三区免费| 国产亚洲毛片| 美女网站一区| 青青青免费在线视频| 久久永久免费| 欧美交a欧美精品喷水| 欧美亚洲三区| 久久国产欧美日韩精品| 久热精品在线| 日韩午夜av在线| 亚州av乱码久久精品蜜桃| 97se综合| 欧洲av一区二区| 久久精品影视| 亚洲成人va| 三上亚洲一区二区| 激情久久一区二区| 麻豆一区二区三| 国产高清日韩| 美女久久久精品| 成人国产精品久久| 色婷婷综合网| 日韩电影免费网址| 欧美日韩在线观看首页| 国产乱码午夜在线视频| bbw在线视频| av资源亚洲| 日韩av首页| 免费欧美一区| 亚洲免费中文| 最新日韩欧美| 中文字幕成人| 日韩精品一区二区三区免费视频| 亚洲精品四区| 欧美亚洲tv| 日韩中文字幕视频网| 国产一区 二区| 久久在线91| 日本精品不卡| 中文一区二区| 日韩欧美中文字幕电影| 国产欧美日韩免费观看| 国产精品99久久免费观看| 精品一区二区三区视频在线播放 | 激情综合激情| 中文亚洲欧美| 91成人福利| 精品日韩一区| 国内激情久久| 青青草伊人久久| а√天堂8资源中文在线| 欧美国产91| 日本aⅴ免费视频一区二区三区| 欧美激情视频一区二区三区在线播放| 精品理论电影在线| 亚洲一级黄色| 99国产精品视频免费观看一公开| 亚洲专区视频| 水蜜桃久久夜色精品一区| 久久久人人人| 日韩精品免费视频人成| 亚洲黄色免费av| 在线视频亚洲| 国产精品亚洲综合久久| 日韩欧美午夜| 日韩有吗在线观看| 91欧美国产| 爽好久久久欧美精品| 国产精品超碰| av亚洲免费| 青青国产精品| 91嫩草亚洲精品| 美女国产精品| 麻豆精品国产91久久久久久| 91久久久精品国产| 国产欧美久久一区二区三区| 蜜桃av.网站在线观看| 最新国产精品久久久| 国产一区二区三区四区大秀| 免播放器亚洲| 97精品在线| 亚洲影视一区二区三区| 高清av不卡| 国产欧美亚洲一区| 国产精品丝袜xxxxxxx| 色婷婷色综合| 亚欧洲精品视频在线观看| 久久在线视频免费观看| 国产一卡不卡| 爽好久久久欧美精品| 日韩电影在线视频| 欧美日韩一区二区三区不卡视频 | 日本色综合中文字幕| 91精品一区二区三区综合在线爱 | 国产精品nxnn| 亚洲一区二区日韩| 国产麻豆久久| 精品视频高潮| 欧美日韩午夜电影网| 欧美午夜不卡| 一区二区三区四区日本视频| 日本国产欧美| 亚洲一区欧美激情| 激情欧美亚洲| 亚洲成人va| 久久国产精品美女| 欧美影院视频| 色婷婷成人网| 日韩专区一卡二卡| 亚洲一区激情| 中文欧美日韩| 99国产精品久久久久久久| 久久国产日本精品| 国产一区2区| 欧美成人精品一级| 国产欧美日韩视频在线| 一区二区三区四区日韩| 欧美日韩国产一区精品一区| 精品免费av在线| 深夜福利视频一区二区| 国产午夜一区| 日韩高清不卡在线| 日韩一区二区三区免费视频| 丝袜美腿亚洲色图| 日韩一区二区久久| 欧美日韩一二三四| 欧美一区二区性| 欧美亚洲国产一区| 亚洲一级影院|