中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在vue中實現裁切預覽組件功能

發布時間:2021-05-22 17:10:59 來源:億速云 閱讀:198 作者:Leah 欄目:web開發

本篇文章給大家分享的是有關怎么在vue中實現裁切預覽組件功能,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

第一步:先用vue-cli安裝腳手架(不會安裝的看 vue-cli官網)

// 初始化vue-cli
vue init webpack my-plugin

第二步:創建文件

新建src/views/validSlideDemo.vue,

src/components里新建VueCrop/index.js,VueCrop.vue,

在routes/index.js配置訪問路由(具體看github源碼)

最終生成的文件結構如下圖:

怎么在vue中實現裁切預覽組件功能 

第三步:注冊組件

1.引用所有插件:src/components/index.js

// 導入插件入口文件
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內單獨引入這個插件,如果是main.js全局引入就可以去掉
 VueCrop
}

2.全局調用插件:src/main.js ( vue plugins官方文檔解說install )

import Vue from 'vue'
import App from './App'
import router from './router'
// 新加的:導入入口文件
import { install } from 'src/components/index.js'
// 全局調用,相當于調用 `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入口文件調用VueCrop.vue:src/components/VueCrop/index.js

// 導入vue
import VueCrop from './VueCrop.vue'
// Vue.js 的插件應當有一個公開方法 install 。這個方法的第一個參數是 Vue 構造器
VueCrop.install = function (Vue) {
 // 注冊組件
 Vue.component(VueCrop.name, VueCrop)
}
export default VueCrop

小結:我一開始一直有個誤解,以為myPlugin.install是vue的一個方法,其實不是,他只是我們構造plugin識的一個公開方法,可以理解為原生js中的構造函數的方法:

function MyPlugin(){
 console.info('構造函數')
}
MyPlugin.prototype.install=function(vue,options){
 console.info('構造器vue:'+vue);
}

而真正注冊組件的是:Vue.component()

所以,vue插件注冊的過程是:

1.調用main.js中:

import { install } from 'src/components/index.js'
vue.use(install)

2.index.js添加install方法,調用Vue.component注冊組件

3.組件內的index.js同所有組件的index.js一樣

第四步:設計開發自己的組件,構建組件結構

在此之前,可以先了解下組件的命名規范等,可參考文章 掘金:Vue前端開發規范 ,其中第2點有詳細講解

首先,確定自己的調用方式和需要暴露的參數

<vue-crop
:crop-url="cropUrl1"
:ratio="ratio"
:height="460"
:width="460"
:previewJson="previewJson1"
class="c-crop--preview_right"
@afterCrop="afterCrop"
>
>

其中,@afterCrop="afterCrop"是裁切完成的回調函數,其他是屬性配置

在組件src/components/VueCrop/VueCrop.vue內,可以用this.$emit('afterCrop')觸發demo里的afterCrop事件

組件結構上,主要分為:裁切主要部分,選框組件(VueCropTool.vue),裁切框寬度、位置坐標等計算(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) {
   // 調用參數中start函數
   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) {
   // 調用參數中end函數
   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

Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以創建可維護性和可測試性更強的代碼庫,Vue允許可以將一個網頁分割成可復用的組件,每個組件都包含屬于自己的HTML、CSS、JavaScript,以用來渲染網頁中相應的地方,所以越來越多的前端開發者使用vue。

以上就是怎么在vue中實現裁切預覽組件功能,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

东城区| 青神县| 双柏县| 繁昌县| 将乐县| 东海县| 额尔古纳市| 灵川县| 西吉县| 双鸭山市| 宜川县| 石门县| 都兰县| 赤峰市| 定南县| 邵阳县| 巴林左旗| 合山市| 顺义区| 红桥区| 离岛区| 洛扎县| 阜南县| 文成县| 阳朔县| 涟源市| 寻乌县| 农安县| 无锡市| 大关县| 景泰县| 且末县| 漳浦县| 炉霍县| 云浮市| 神农架林区| 通河县| 青海省| 台前县| 黔西县| 潞城市|