vue裁切預(yù)覽組件功能的實(shí)現(xiàn)步驟
vue版本裁切工具,包含預(yù)覽功能
最終效果: qiuyaofan.github.io/vue-crop-de…
源碼地址: github.com/qiuyaofan/v…
第一步:先用vue-cli安裝腳手架(不會(huì)安裝的看 vue-cli官網(wǎng))
// 初始化vue-cli vue init webpack my-plugin
第二步:創(chuàng)建文件
新建src/views/validSlideDemo.vue,
src/components里新建VueCrop/index.js,VueCrop.vue,
在routes/index.js配置訪(fǎng)問(wèn)路由(具體看github源碼)
最終生成的文件結(jié)構(gòu)如下圖:
第三步:注冊(cè)組件
1.引用所有插件:src/components/index.js
// 導(dǎo)入插件入口文件
import VueCrop from './VueCrop/index.js'
const install = function (Vue, opts = {}) {
/* 如果已安裝就跳過(guò) */
if (install.installed) return
// 注冊(cè)插件
Vue.component(VueCrop.name, VueCrop)
}
// 全局情況下注冊(cè)插件
if (typeof window !== 'undefined' && window.Vue) {
install(window.Vue)
}
export {
install,
// 此處是為了兼容在vue內(nèi)單獨(dú)引入這個(gè)插件,如果是main.js全局引入就可以去掉
VueCrop
}
2.全局調(diào)用插件:src/main.js ( vue plugins官方文檔解說(shuō)install )
import Vue from 'vue'
import App from './App'
import router from './router'
// 新加的:導(dǎo)入入口文件
import { install } from 'src/components/index.js'
// 全局調(diào)用,相當(dāng)于調(diào)用 `MyPlugin.install(Vue)`
Vue.use(install)
Vue.config.productionTip = false
/* eslint-disable no-new */
new Vue({
el: '#app',
router,
components: { App },
template: '<App/>'
})
3.VueCrop入口文件調(diào)用VueCrop.vue:src/components/VueCrop/index.js
// 導(dǎo)入vue
import VueCrop from './VueCrop.vue'
// Vue.js 的插件應(yīng)當(dāng)有一個(gè)公開(kāi)方法 install 。這個(gè)方法的第一個(gè)參數(shù)是 Vue 構(gòu)造器
VueCrop.install = function (Vue) {
// 注冊(cè)組件
Vue.component(VueCrop.name, VueCrop)
}
export default VueCrop
小結(jié):我一開(kāi)始一直有個(gè)誤解,以為myPlugin.install是vue的一個(gè)方法,其實(shí)不是,他只是我們構(gòu)造plugin識(shí)的一個(gè)公開(kāi)方法,可以理解為原生js中的構(gòu)造函數(shù)的方法:
function MyPlugin(){
console.info('構(gòu)造函數(shù)')
}
MyPlugin.prototype.install=function(vue,options){
console.info('構(gòu)造器vue:'+vue);
}
而真正注冊(cè)組件的是:Vue.component()
所以,vue插件注冊(cè)的過(guò)程是:
1.調(diào)用main.js中:
import { install } from 'src/components/index.js'
vue.use(install)
2.index.js添加install方法,調(diào)用Vue.component注冊(cè)組件
3.組件內(nèi)的index.js同所有組件的index.js一樣
第四步:設(shè)計(jì)開(kāi)發(fā)自己的組件,構(gòu)建組件結(jié)構(gòu)
在此之前,可以先了解下組件的命名規(guī)范等,可參考文章 掘金:Vue前端開(kāi)發(fā)規(guī)范 ,其中第2點(diǎn)有詳細(xì)講解
首先,確定自己的調(diào)用方式和需要暴露的參數(shù)
<vue-crop :crop-url="cropUrl1" :ratio="ratio" :height="460" :width="460" :previewJson="previewJson1" class="c-crop--preview_right" @afterCrop="afterCrop" > >
其中,@afterCrop="afterCrop"是裁切完成的回調(diào)函數(shù),其他是屬性配置
在組件src/components/VueCrop/VueCrop.vue內(nèi),可以用this.$emit('afterCrop')觸發(fā)demo里的afterCrop事件
組件結(jié)構(gòu)上,主要分為:裁切主要部分,選框組件(VueCropTool.vue),裁切框?qū)挾?、位置坐?biāo)等計(jì)算(VueCropMove.js),拖拽事件注冊(cè)公共js(components/utils/draggable.js)
draggable.js是參照element里的,修改了一部分,源碼如下
export default function (element, options) {
const moveFn = function (event) {
if (options.drag) {
options.drag(event)
}
}
// mousedown fn
const downFn = function (event) {
if (options.start) {
// 調(diào)用參數(shù)中start函數(shù)
options.start(event)
}
}
// mouseup fn
const upFn = function (event) {
document.removeEventListener('mousemove', moveFn)
document.removeEventListener('mouseup', upFn)
document.onselectstart = null
document.ondragstart = null
if (options.end) {
// 調(diào)用參數(shù)中end函數(shù)
options.end(event)
}
}
// 綁定事件
element.addEventListener('mousedown', event => {
if (options.stop && options.stop(event, element) === false) {
return false
}
document.onselectstart = function () {
return false
}
document.ondragstart = function () {
return false
}
document.addEventListener('mousedown', downFn)
document.addEventListener('mousemove', moveFn)
document.addEventListener('mouseup', upFn)
})
}
總結(jié)
以上所述是小編給大家介紹的vue裁切預(yù)覽組件功能的實(shí)現(xiàn)步驟,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- 在Vue項(xiàng)目中,防止頁(yè)面被縮放和放大示例
- vue中element-ui表格縮略圖懸浮放大功能的實(shí)例代碼
- vue實(shí)現(xiàn)裁切圖片同時(shí)實(shí)現(xiàn)放大、縮小、旋轉(zhuǎn)功能
- 基于vue2.x的電商圖片放大鏡插件的使用
- vue實(shí)現(xiàn)點(diǎn)擊圖片放大效果
- vue.js+Echarts開(kāi)發(fā)圖表放大縮小功能實(shí)例
- vue實(shí)現(xiàn)圖片上傳預(yù)覽功能
- vue實(shí)現(xiàn)圖片預(yù)覽組件封裝與使用
- Vue + Node.js + MongoDB圖片上傳組件實(shí)現(xiàn)圖片預(yù)覽和刪除功能詳解
- vue.js實(shí)現(xiàn)雙擊放大預(yù)覽功能
相關(guān)文章
Vue render渲染時(shí)間戳轉(zhuǎn)時(shí)間,時(shí)間轉(zhuǎn)時(shí)間戳及渲染進(jìn)度條效果
這篇文章主要介紹了Vue render渲染時(shí)間戳轉(zhuǎn)時(shí)間,時(shí)間轉(zhuǎn)時(shí)間戳及渲染進(jìn)度條效果,通過(guò)實(shí)例代碼相結(jié)合的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-07-07
vue3+vite項(xiàng)目中顯示SVG圖片的實(shí)現(xiàn)
vite-plugin-svg-icons是一個(gè)Vite插件,其作用是將SVG圖標(biāo)文件轉(zhuǎn)換為Vue組件,本文主要介紹了vue3+vite項(xiàng)目中顯示SVG圖片的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02
基于Vue 2.0 監(jiān)聽(tīng)文本框內(nèi)容變化及ref的使用說(shuō)明介紹
今天小編就為大家分享一篇基于Vue 2.0 監(jiān)聽(tīng)文本框內(nèi)容變化及ref的使用說(shuō)明介紹,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08
vue截圖轉(zhuǎn)base64轉(zhuǎn)文件File異步獲取方式
這篇文章主要介紹了vue截圖轉(zhuǎn)base64轉(zhuǎn)文件File異步獲取方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
vue3.0使用vue-pdf-embed在線(xiàn)預(yù)覽pdf 控制頁(yè)碼顯示范圍不生效問(wèn)題解決
這篇文章主要介紹了vue3.0使用vue-pdf-embed在線(xiàn)預(yù)覽pdf 控制頁(yè)碼顯示范圍不生效問(wèn)題的問(wèn)題及解決方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-01-01
vite/Vuecli配置proxy代理解決跨域問(wèn)題
這篇文章主要介紹了vite/Vuecli配置proxy代理解決跨域問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12
Vue 路由組件向app.vue主文件傳值的方式(兩種常見(jiàn)方式)
在Vue.js中,可以使用路由傳參的方式向App.vue主頁(yè)面?zhèn)鬟f數(shù)據(jù),有多種方法可以實(shí)現(xiàn)這一目標(biāo),本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2023-11-11
vue3+Element?Plus?v-model實(shí)現(xiàn)父子組件數(shù)據(jù)同步的案例代碼
這篇文章主要介紹了vue3+Element?Plus?v-model實(shí)現(xiàn)父子組件數(shù)據(jù)同步,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2024-01-01

