div实现拖拽效果,宽度发生变化

这篇博客演示了如何利用jQuery实现一个div元素的拖拽功能,通过拖动div之间的边框,可以动态改变div的宽度。示例中包含了CSS样式和JavaScript代码,展示了在页面上创建三个并排的div,用户可以拖动中间的边框来调整左右两个div的宽度。
摘要由CSDN通过智能技术生成

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<title>jquery拖拽改变div大小效果</title>
<meta name="keywords" content="jquery拖拽,改变大小" />
<meta name="description" content="jquery拖拽改变div大小效果" />

<style>
*{margin:0;padding:0;}
ul,ol,li{list-style: none;}
#wrap{width:660px;height: 150px;margin:10px auto;position: relative;clear:both;background: #0cc;}
#wrap li{width: 220px;float: left;height: 150px;background: #ccc;overflow: hidden;
        text-align: center;line-height: 50px;}
#wrap li.li1{background: #777;}
#wrap li.li2{background: #ccc;}
#wrap li.li3{background: #999;}
#wrap label{float: left;width: 10px;height: 150px;
            position: absolute;cursor: e-resize

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用vue-resizable-box这个插件来实现一个宽度拖拽div。 1. 安装vue-resizable-box 可以通过npm或yarn来安装vue-resizable-box: ``` npm install vue-resizable-box --save ``` ``` yarn add vue-resizable-box ``` 2. 在组件中使用vue-resizable-box 在需要使用可拖拽宽度div的组件中,引入vue-resizable-box组件,并在template中使用它: ```vue <template> <div> <vue-resizable-box :width="width" :min-width="200" :max-width="600" @resize="onResize" > <div class="content">可拖拽宽度div</div> </vue-resizable-box> </div> </template> <script> import VueResizableBox from 'vue-resizable-box'; export default { name: 'MyComponent', components: { VueResizableBox, }, data() { return { width: 300, }; }, methods: { onResize(newWidth) { this.width = newWidth; }, }, }; </script> ``` 在上面的代码中,我们引入了vue-resizable-box组件,并在template中使用它。其中,width属性控制div宽度,min-width和max-width属性分别控制div的最小和最大宽度。@resize事件监听div宽度变化,并调用onResize方法更新div宽度。 3. 样式调整 为了让vue-resizable-box的表现更符合实际需求,我们需要调整一些样式: ```css .vue-resizable-box { position: relative; overflow: hidden; } .vue-resizable-box .vue-resizable-handle { position: absolute; top: 0; right: 0; width: 10px; height: 100%; cursor: e-resize; z-index: 1; background-color: rgba(0, 0, 0, 0.1); } .vue-resizable-box .content { height: 100%; background-color: #fff; padding: 10px; } ``` 在上面的代码中,我们将vue-resizable-box设置为相对定位,并隐藏超出范围的内容。vue-resizable-handle是拖拽宽度的手柄,我们将它设置为绝对定位,并调整样式。content是div的内容区域,我们将它设置为与父元素等高,并设置背景色和内边距。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值