Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537
建了一個新的 vue3 項目,因為項目中有很多模塊用到了圖片預覽功能,項目的 ui 框架用的是element-plus,框架自帶 el-image 組件里面帶了圖片預覽功能,但是當時我不想用這個組件,所以就借鑒了它里面預覽圖片組件的代碼。
簡單的例子
<div v-color="red"> 我是紅色的文字</div>
app.directive('color', (el, binding)=> {
// 這會在 `mounted` 和 `updated` 時都調用
el.style.color=binding.value
})
這時候 div 里面的文字都變成紅色, v-color="yellow" 就變成了黃色
相關參數介紹
導入相關函數及類型,編寫基本的指令代碼
import { DirectiveBinding, h, render } from 'vue';
import { ElImageViewer } from 'element-plus';
export default function (app) {
app.directive('previewImage', {
mounted(el: HTMLElement, binding: DirectiveBinding) {
// 邏輯操作
},
});
}
下面開始編寫相關指令代碼
首先我們需要創建一個 div 用來包裹我們的預覽組件,我們來控制這個 div 的顯示隱藏來實現預覽組件的彈出和隱藏。
為什么這幾個變量為啥要定義成全局的,如果寫在指令內部 v-previewImage="" 多次 就出現多個變量,和多個組件,造成了資源浪費,然后ElImageViewer組件一個頁面要寫多次還會出現一個錯誤
我給 element 提了issues,現在已經修復,但還是推薦我這種寫法
const previewBox=document.createElement('div'); // 創建節點
previewBox.classList.add('preview-box'); // 給 div 增加類名
let vnode; // 存放 vnode 的變量
編寫指令內部代碼
export default function (app) {
app.directive('previewImage', {
mounted(el: HTMLElement, binding: DirectiveBinding) {
el.addEventListener('click', ()=> {
el.style.cursor='pointer';
})
},
});
}
export default function (app) {
app.directive('previewImage', {
mounted(el: HTMLElement, binding: DirectiveBinding) {
el.addEventListener('click', ()=> {
el.style.cursor='pointer';
})
vnode=h(ElImageViewer, {
urlList: [binding.value], // 圖片地址
hideOnClickModal: true, // 允許點擊遮罩層關閉
});
},
});
}
export default function (app) {
app.directive('previewImage', {
mounted(el: HTMLElement, binding: DirectiveBinding) {
el.addEventListener('click', ()=> {
el.style.cursor='pointer';
})
vnode=h(ElImageViewer, {
urlList: [binding.value], // 圖片地址
hideOnClickModal: true, // 允許點擊遮罩層關閉
});
render(vnode, previewBox); // 將 vnode 渲染成 html
document.body.appendChild(previewBox); // 將 html 插入到 body 標簽里面
},
});
}
到現在為止我們點擊圖片組件已經可以正常的顯示了
export default function (app) {
app.directive('previewImage', {
mounted(el: HTMLElement, binding: DirectiveBinding) {
el.addEventListener('click', ()=> {
el.style.cursor='pointer';
})
vnode=h(ElImageViewer, {
urlList: [binding.value], // 圖片地址
hideOnClickModal: true, // 允許點擊遮罩層關閉
onClose: ()=> {
el.removeEventListener('click', ()=> {}); // 移除
document.body.removeChild(previewBox);
},
});
render(vnode, previewBox); // 將 vnode 渲染成 html
document.body.appendChild(previewBox); // 將 html 插入到 body 標簽里面
},
});
}
將文件導入 main.ts中然后調用我們導入的方法傳入 app 就可以在頁面中使用了
import imageDirective from 'xxxx/previewImageDirective';
const app=createApp(App);
imageDirective(app)
ok 上面就是完整代碼,這樣一個圖片預覽指令就完成了
使用 vue3 指令封裝一個后臺管理系統圖片預覽功能
原文鏈接:https://juejin.cn/post/7324653675456364596
天給小伙伴們分享一個超棒的Vue圖片任意裁剪插件VueImgCutter。
vue-img-cutter 基于 vue2.x 構建的輕量級剪切圖片組件。支持移動圖像、放大縮小圖片、任意移動圖片、固定比例/尺寸、遠程圖片裁剪等功能。
功能特色
安裝
$ npm i vue-img-cutter -S
使用插件
<template>
<div id="app">
<ImgCutter
label="選擇圖片"
:isModal="false"
:boxWidth="800"
:boxHeight="500"
:cutWidth="300"
:cutHeight="300"
:sizeChange="true"
:moveAble="true"
WatermarkText="水印文字"
v-on:cutDown="cutDown"
>
<div class="btn btn-primary" slot="open">選擇本地圖片</div>
</ImgCutter>
</div>
</template>
<script>
import ImgCutter from 'vue-img-cutter'
export default {
components: { ImgCutter },
data() {
return {}
},
methods: {
cutDown(res) {
let imgSrc=res.dataURL;
console.log(imgSrc);//輸出為base64數據
}
}
}
</script>
設置模態彈框模式
<ImgCutter :isModal="true"></ImgCutter>
模態框模式
參數配置
插槽Slot
<ImgCutter v-on:cutDown="cutDown">
<button slot="open">選擇圖片</button>
</ImgCutter>
返回值
最后附上示例及項目地址
# 演示地址
https://ihtmlcss.com/demo/dist/#/croptool
# 倉庫地址
https://github.com/acccccccb/vue-img-cutter
ok,就介紹到這里。希望對你有幫助!感興趣的同學可以去了解下哈~
為了豐富 Naive Admin 生態,近期我們一直在精雕細琢,日夜奮戰,終于又迎來了Arco Vue Pro 正式發布上線!
ArcoDesign 是由字節跳動 GIP UED 團隊和架構前端團隊聯合推出的企業級設計系統,在打磨了近 3 年之后,通過字節內部大量業務沉淀和驗證,開源了 ArcoDesign 設計系統,旨在讓社區聽見更多的聲音,為更多中小型企業及個人設計師和開發者提效,創造更多高效美觀的“最佳實踐”。
Naive Admin Arco 是一個基于 Vue3.0、Vite、 Arco Vue、TypeScript 中后臺解決方案。
Naive Admin Arco 企業級中后臺前端框架,使用最新的前端技術棧,并提煉了典型的業務模型,頁面,包括二次封裝組件、動態菜單、權限校驗、粒子化權限控制等功能,它可以幫助你快速搭建企業級中后臺項目
響應式、多主題,多配置,快速集成,開箱即用
最新技術棧,使用 Vue 3、Typescript、Pinia、Vite 等前端前沿技術
強大的鑒權系統,對路由、菜單、功能點等支持 3 種鑒權模式,滿足不同的業務鑒權需求
持續更新,實用性頁面模板功能和交互,隨意搭配組合,讓構建頁面變得簡單化
更多頁面、功能,組件,請直接在線預覽查看
AdminPro
Naive Admin NaiveUi 生態最優秀的中后臺框架,全面的系統配置,優質模板,常用組件,真正一站式開箱即用
*請認真填寫需求信息,我們會在24小時內與您取得聯系。