欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

VUE實(shí)現(xiàn)Studio管理后臺(tái)之鼠標(biāo)拖放改變窗口大小

 更新時(shí)間:2020年03月04日 16:09:59   作者:悠閑的水  
這篇文章主要介紹了VUE實(shí)現(xiàn)Studio管理后臺(tái)之鼠標(biāo)拖放改變窗口大小 的相關(guān)知識(shí),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的工作或?qū)W習(xí)具有一定的參考價(jià)值,需要的朋友可以參考下

近期改版RXEditor,把改版過(guò)程,用到的技術(shù)點(diǎn),記錄下來(lái)。昨天完成了靜態(tài)頁(yè)面的制作,制作過(guò)程并未詳細(xì)記錄,后期已經(jīng)不愿再補(bǔ)了,有些遺憾。不過(guò)工作成果完整保留在github上,地址:https://github.com/vularsoft/studio-ui

這個(gè)項(xiàng)目下面的html-demo.html,便是靜態(tài)文件。

話不多說(shuō),今天就把昨天的HTML轉(zhuǎn)化成VUE。

先看效果:

布局原理

頁(yè)面采用純彈性盒子flex box布局,無(wú)float postion等,頁(yè)面分成如下幾個(gè)區(qū)域:

細(xì)實(shí)線描述的是各個(gè)DIV之間的嵌套關(guān)系,粗黑線是獨(dú)立的DIV,我稱它們?yōu)榘咽郑℉ADLE),主要用來(lái)接受鼠標(biāo)拖動(dòng)事件,以完成拖動(dòng)操作。handle非為兩種,橫向x-handle,縱向y-handle,css中定義x-handle寬度為3px,高度為100%,y-handle高度為3px,寬度為100%,鼠標(biāo)光標(biāo)也相應(yīng)設(shè)置一下:

.vular-studio .x-handle{
 width: 3px;
 cursor: w-resize;
 z-index: 10;
}

.vular-studio .y-handle{
 height: 3px;
 cursor: s-resize;
 z-index: 10;
}

拖動(dòng)原理

帶有把手的區(qū)域固定大?。ü潭▽挾然蛘吒叨龋?,不帶把手的部分跟隨彈性盒子變化。把手handle是一個(gè)獨(dú)立的VUE組件,它把拖動(dòng)信息傳遞給父窗口,父窗口改變自身大小。以bottom-area為例,這是一個(gè)可以改變自身大小的DIV:

<template>
 <div class="bottom-area" :style="{height:height + 'px'}">
 <YHandle @heightChange="heightChange"></YHandle>
 <div class="bottom-inner">
  <slot></slot>
 </div>
 </div>
</template>

<script>
import YHandle from './YHandle.vue'
export default {
 name: 'BottomArea',
 components:{
 YHandle,
 },
 data () {
 return {
  height:220,
 }
 },
 methods: {
 heightChange(movement){
  this.height += movement
  if(this.height < 30){
  this.height = 30
  }
  if(this.height > 600){
  this.height = 600
  }
 },
 },
}
</script>

它對(duì)應(yīng)的把手代碼:

<template>
 <div class="y-handle" 
 @mousedown="mouseDown" 
 ></div>
</template>

<script>
export default {
 name: 'YHandle',
 data () {
 return {
  lastY:''
 }
 },

 created () {
 document.addEventListener('mouseup', this.mouseUp)
 },

 destroyed() {
 document.removeEventListener('mouseup', this.mouseUp)
 },


 methods: {
 mouseDown(event){
  document.addEventListener('mousemove', this.mouseMove)
  this.lastY = event.screenY
 },
 mouseMove(event){
  console.log('move')
  this.$emit('heightChange', this.lastY - event.screenY)
  this.lastY = event.screenY
 },
 mouseUp(event){
  this.lastY = ''
  document.removeEventListener('mousemove', this.mouseMove)
 },
 },
}
</script>

制作步驟

先建一個(gè)VUE項(xiàng)目:
1、安裝node
2、安裝webpack
3、安裝VUE
4、新建VUE項(xiàng)目:vue init webpack-simple
5、根據(jù)相應(yīng)布局制作VUE組件
具體代碼,請(qǐng)參考:https://github.com/vularsoft/studio-ui,根據(jù)標(biāo)注,獲取相應(yīng)的版本記錄即可。

到此這篇關(guān)于VUE實(shí)現(xiàn)Studio管理后臺(tái)之鼠標(biāo)拖放改變窗口大小 的文章就介紹到這了,更多相關(guān)vue 鼠標(biāo)拖放改變窗口大小 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue如何將字符串變?yōu)閿?shù)組

    vue如何將字符串變?yōu)閿?shù)組

    這篇文章主要介紹了vue如何將字符串變?yōu)閿?shù)組問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • vue-cli 3.x配置跨域代理的實(shí)現(xiàn)方法

    vue-cli 3.x配置跨域代理的實(shí)現(xiàn)方法

    這篇文章主要介紹了vue-cli 3.x配置跨域代理的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • vue項(xiàng)目動(dòng)態(tài)設(shè)置iframe元素高度的操作代碼

    vue項(xiàng)目動(dòng)態(tài)設(shè)置iframe元素高度的操作代碼

    在現(xiàn)代Web開(kāi)發(fā)中,iframe元素常用于嵌入外部?jī)?nèi)容到當(dāng)前網(wǎng)頁(yè)中,比如在線文檔、視頻播放器或是廣告,Vue框架提供了強(qiáng)大的工具來(lái)解決這個(gè)問(wèn)題,通過(guò)動(dòng)態(tài)設(shè)置iframe元素的高度,我們可以確保頁(yè)面布局既美觀又高效,本文給大家介紹了vue項(xiàng)目動(dòng)態(tài)設(shè)置iframe元素高度的操作
    2024-10-10
  • vue 實(shí)現(xiàn)網(wǎng)頁(yè)截圖功能詳解

    vue 實(shí)現(xiàn)網(wǎng)頁(yè)截圖功能詳解

    這篇文章主要介紹了通過(guò)vue實(shí)現(xiàn)網(wǎng)頁(yè)截圖的功能,有興趣的童鞋可以了解一下
    2021-11-11
  • vue如何動(dòng)態(tài)給img賦值

    vue如何動(dòng)態(tài)給img賦值

    這篇文章主要介紹了vue如何動(dòng)態(tài)給img賦值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • Vue項(xiàng)目首屏性能優(yōu)化組件實(shí)戰(zhàn)指南

    Vue項(xiàng)目首屏性能優(yōu)化組件實(shí)戰(zhàn)指南

    Vue眾所周知是一個(gè)輕量級(jí)的框架,源碼僅僅為72.9KB,但是也有它自己的缺點(diǎn),就是首屏加載會(huì)比較慢,這篇文章主要給大家介紹了關(guān)于Vue項(xiàng)目首屏性能優(yōu)化組件的相關(guān)資料,需要的朋友可以參考下
    2021-11-11
  • vue中this.$refs有值,但無(wú)法獲取ref的值問(wèn)題及解決

    vue中this.$refs有值,但無(wú)法獲取ref的值問(wèn)題及解決

    這篇文章主要介紹了vue中this.$refs有值,但無(wú)法獲取ref的值問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • 基于Vue3實(shí)現(xiàn)組件封裝的技巧分享

    基于Vue3實(shí)現(xiàn)組件封裝的技巧分享

    這篇文章主要介紹了基于Vue3實(shí)現(xiàn)組件封裝的技巧,本文在Vue3的基礎(chǔ)上針對(duì)一些常見(jiàn)UI組件庫(kù)組件進(jìn)行二次封裝,旨在追求更好的個(gè)性化,更靈活的拓展,感興趣的小伙伴跟著小編一起來(lái)看看吧
    2024-09-09
  • vue組件強(qiáng)制刷新的4種方案

    vue組件強(qiáng)制刷新的4種方案

    在開(kāi)發(fā)過(guò)程中,有時(shí)候會(huì)遇到這么一種情況,通過(guò)動(dòng)態(tài)的賦值,但是dom沒(méi)有及時(shí)更新,能夠獲取到動(dòng)態(tài)賦的值,但是無(wú)法獲取到雙向綁定的dom節(jié)點(diǎn),這就需要我們手動(dòng)進(jìn)行強(qiáng)制刷新組件,下面這篇文章主要給大家介紹了關(guān)于vue組件強(qiáng)制刷新的4種方案,需要的朋友可以參考下
    2023-05-05
  • vuex中Getter的用法詳解

    vuex中Getter的用法詳解

    這篇文章主要給大家介紹了關(guān)于Vuex中Getter的基本使用教程,getter相當(dāng)于Vuex中的計(jì)算屬性 對(duì) state 做處理再返回,本文通過(guò)示例代碼將Getter介紹的非常詳細(xì),需要的朋友可以參考下
    2021-07-07

最新評(píng)論