本篇文章給大家分享的是有關(guān)怎么在vue中實現(xiàn)裁切預(yù)覽組件功能,小編覺得挺實用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),賽罕企業(yè)網(wǎng)站建設(shè),賽罕品牌網(wǎng)站建設(shè),網(wǎng)站定制,賽罕網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,賽罕網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。
第一步:先用vue-cli安裝腳手架(不會安裝的看 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配置訪問路由(具體看github源碼)
最終生成的文件結(jié)構(gòu)如下圖:
第三步:注冊組件
1.引用所有插件:src/components/index.js
// 導(dǎo)入插件入口文件 import VueCrop from './VueCrop/index.js' const install = function (Vue, opts = {}) { /* 如果已安裝就跳過 */ if (install.installed) return // 注冊插件 Vue.component(VueCrop.name, VueCrop) } // 全局情況下注冊插件 if (typeof window !== 'undefined' && window.Vue) { install(window.Vue) } export { install, // 此處是為了兼容在vue內(nèi)單獨引入這個插件,如果是main.js全局引入就可以去掉 VueCrop }
2.全局調(diào)用插件:src/main.js ( vue plugins官方文檔解說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)有一個公開方法 install 。這個方法的第一個參數(shù)是 Vue 構(gòu)造器 VueCrop.install = function (Vue) { // 注冊組件 Vue.component(VueCrop.name, VueCrop) } export default VueCrop
小結(jié):我一開始一直有個誤解,以為myPlugin.install是vue的一個方法,其實不是,他只是我們構(gòu)造plugin識的一個公開方法,可以理解為原生js中的構(gòu)造函數(shù)的方法:
function MyPlugin(){ console.info('構(gòu)造函數(shù)') } MyPlugin.prototype.install=function(vue,options){ console.info('構(gòu)造器vue:'+vue); }
而真正注冊組件的是:Vue.component()
所以,vue插件注冊的過程是:
1.調(diào)用main.js中:
import { install } from 'src/components/index.js' vue.use(install)
2.index.js添加install方法,調(diào)用Vue.component注冊組件
3.組件內(nèi)的index.js同所有組件的index.js一樣
第四步:設(shè)計開發(fā)自己的組件,構(gòu)建組件結(jié)構(gòu)
在此之前,可以先了解下組件的命名規(guī)范等,可參考文章 掘金:Vue前端開發(fā)規(guī)范 ,其中第2點有詳細講解
首先,確定自己的調(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ū)挾?、位置坐標等計算(VueCropMove.js),拖拽事件注冊公共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) }) }
Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以創(chuàng)建可維護性和可測試性更強的代碼庫,Vue允許可以將一個網(wǎng)頁分割成可復(fù)用的組件,每個組件都包含屬于自己的HTML、CSS、JavaScript,以用來渲染網(wǎng)頁中相應(yīng)的地方,所以越來越多的前端開發(fā)者使用vue。
以上就是怎么在vue中實現(xiàn)裁切預(yù)覽組件功能,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降?。希望你能通過這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
文章名稱:怎么在vue中實現(xiàn)裁切預(yù)覽組件功能
瀏覽路徑:http://muchs.cn/article26/jpiijg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供小程序開發(fā)、定制網(wǎng)站、營銷型網(wǎng)站建設(shè)、手機網(wǎng)站建設(shè)、云服務(wù)器、建站公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)