亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue裁切預(yù)覽組件功能的實(shí)現(xiàn)步驟

 更新時(shí)間:2018年05月04日 09:08:59   作者:飯妖精  
這篇文章主要介紹了vue裁切預(yù)覽組件功能的實(shí)現(xiàn)代碼,本文通過實(shí)例代碼相結(jié)合的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧

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配置訪問路由(具體看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)單獨(dú)引入這個(gè)插件,如果是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)有一個(gè)公開方法 install 。這個(gè)方法的第一個(gè)參數(shù)是 Vue 構(gòu)造器
VueCrop.install = function (Vue) {
 // 注冊組件
 Vue.component(VueCrop.name, VueCrop)
}
export default VueCrop

小結(jié):我一開始一直有個(gè)誤解,以為myPlugin.install是vue的一個(gè)方法,其實(shí)不是,他只是我們構(gòu)造plugin識(shí)的一個(gè)公開方法,可以理解為原生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è)計(jì)開發(fā)自己的組件,構(gòu)建組件結(jié)構(gòu)

在此之前,可以先了解下組件的命名規(guī)范等,可參考文章 掘金:Vue前端開發(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),拖拽事件注冊公共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)步驟,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 發(fā)布訂閱模式在vue中的實(shí)際運(yùn)用實(shí)例詳解

    發(fā)布訂閱模式在vue中的實(shí)際運(yùn)用實(shí)例詳解

    訂閱發(fā)布模式定義了一種一對多的依賴關(guān)系,讓多個(gè)訂閱者對象同時(shí)監(jiān)聽某一個(gè)主題對象。這篇文章主要介紹了發(fā)布訂閱模式在vue中的實(shí)際運(yùn)用,需要的朋友可以參考下
    2019-06-06
  • vue style width a href動(dòng)態(tài)拼接問題的解決

    vue style width a href動(dòng)態(tài)拼接問題的解決

    這篇文章主要介紹了vue style width a href動(dòng)態(tài)拼接問題的解決,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • vite+vue3+element-plus項(xiàng)目搭建的方法步驟

    vite+vue3+element-plus項(xiàng)目搭建的方法步驟

    因?yàn)関ue3出了一段時(shí)間了,element也出了基于vue3.x版本的element-plus,vite打包聽說很快,嘗試一下,感興趣的可以了解一下
    2021-06-06
  • Vue組織架構(gòu)樹圖組件vue-org-tree的使用解析

    Vue組織架構(gòu)樹圖組件vue-org-tree的使用解析

    這篇文章主要介紹了Vue組織架構(gòu)樹圖組件vue-org-tree的使用解析,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue實(shí)現(xiàn)動(dòng)態(tài)給data函數(shù)中的屬性賦值

    vue實(shí)現(xiàn)動(dòng)態(tài)給data函數(shù)中的屬性賦值

    這篇文章主要介紹了vue實(shí)現(xiàn)動(dòng)態(tài)給data函數(shù)中的屬性賦值,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue post application/x-www-form-urlencoded如何實(shí)現(xiàn)傳參

    vue post application/x-www-form-urlencoded如何實(shí)現(xiàn)傳參

    這篇文章主要介紹了vue post application/x-www-form-urlencoded如何實(shí)現(xiàn)傳參問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • vue3使用canvas的詳細(xì)指南

    vue3使用canvas的詳細(xì)指南

    這篇文章主要給大家介紹了關(guān)于vue3使用canvas的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用vue3具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2023-04-04
  • vue項(xiàng)目打包:修改dist文件名方式

    vue項(xiàng)目打包:修改dist文件名方式

    這篇文章主要介紹了vue項(xiàng)目打包:修改dist文件名方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • vue實(shí)例配置對象中el、template、render的用法

    vue實(shí)例配置對象中el、template、render的用法

    這篇文章主要介紹了vue實(shí)例配置對象中el、template、render的用法,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • 關(guān)于Vue中axios的封裝實(shí)例詳解

    關(guān)于Vue中axios的封裝實(shí)例詳解

    這篇文章主要給大家介紹了關(guān)于Vue中axios的封裝的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者使用Vue具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10

最新評論