The specific usage of the Vue image drag and drop zoom component is for your reference. The specific content is as follows <doc> Image component - user zooms in and out and drags</doc> <template> <div style="width: 100%;position: relative;overflow: hidden;text-align: center;border: 1px solid #f1f2f3;"> <el-button size='mini' @click="toBIgChange" icon="el-icon-zoom-in" style="position: absolute;top: 2px ;left: 2px;z-index: 999;"></el-button> <el-button size='mini' @click="toSmallChange" icon="el-icon-zoom-out" style="position: absolute;top: 2px ;left: 40px;z-index: 999;"></el-button> <img id="img" :src="src" alt="" @mousedown.prevent="dropImage" :style="{transform:'scale('+multiples+')'}"> </div> </template> <script> export default { props: ['src'], data() { return { multiples: 1, odiv: null, } }, mounted() { this.dropImage() }, watch: src(newValue, oldValue) { this.multiples = 1 if (this.odiv !== null) { this.odiv.style.left = '0px'; this.odiv.style.top = '0px'; } }, }, methods: { toBIgChange() { if (this.multiples >= 2) { return; } this.multiples += 0.25; }, //Shrink toSmallChange() { if (this.multiples <= 1) { return; } this.multiples -= 0.25; }, // drag dropImage(e) { if (e === null) { return } this.odiv = e.target; //Get the target element //Calculate the position of the mouse relative to the element let disX = e.clientX - this.odiv.offsetLeft; let disY = e.clientY - this.odiv.offsetTop; document.onmousemove = (e) => { //Mouse pressed and moved event //Subtract the position of the mouse relative to the element from the position of the mouse to get the position of the element let left = e.clientX - disX; let top = e.clientY - disY; //Bind the element position to positionX and positionY this.positionX = top; this.positionY = left; //Move the current element this.odiv.style.left = left + 'px'; this.odiv.style.top = top + 'px'; }; document.onmouseup = (e) => { document.onmousemove = null; document.onmouseup = null; }; }, } } </script> <style scoped> img { width: 100%; position: relative; } </style> The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM. You may also be interested in:
|
<<: How to set the default value of a MySQL field
>>: Detailed explanation of the deployment process of SEATA transaction service Docker
This article example shares the specific code of ...
I have seen some dynamic routing settings on the ...
1. Cleaning before installation rpm -qa | grep jd...
A colleague asked me to help him figure out why m...
Add in the <Head> tag <meta http-equiv=&q...
Table of contents What happens if a piece of code...
I have previously written an article about recurs...
I believe some people have seen this picture of c...
1 CSS style without semicolon ";" 2 Tags...
Table of contents 1. Some points to remember 1. V...
Table of contents 1 What is SSH 2 Configure SSH p...
⑴ Content determines form. First enrich the conten...
Let’s not start with the introduction and get str...
Note: In web development, after adding autocomplet...
Table of contents Array deduplication 1. from() s...