左右滑动栏

展示效果图:

在这里插入图片描述

<template><div ref="topBox" class="swiper-in page-container bg-white"><div class="page-body"><drag-box class="drag-box"><div class="relative" :class="{'expend-border':!slideStateX}" :style="{'width': slideStateX? '350px' : '35px'}" ref="sliderLeft"><drag-item v-show="slideStateX">123</drag-item><div v-if="expendX" :class="slideStateX?'close-box-button-x':'open-box-button-x'" @click="slideStateX = !slideStateX"></div><div v-show="!slideStateX" class="arrow-content text-gray-500">展开侧边栏</div></div><drag-item class="w-4/5 flex-col-box" :resizeShow="false" ref="sliderRight"><div class="flex-auto flex-col-box">123123</div></drag-item></drag-box></div></div>
</template><script>
import { dragBox, dragItem } from '@/components/common/dragLayouter'
export default {components: {dragBox,dragItem},data() {return {expendX: true,slideStateX: true}},watch: {},created(){},methods:{}
}
</script><style scoped>
@import '../../assets/css/basicPageTemplate/basicPageTemplate.css';
.topbox {padding: 1rem;border-bottom: 1px solid #ccc;
}
</style>

子1

<template><div ref="container" class="d-flex"><slot>默认信息</slot><!-- 拖拽条 --><div v-if="resizeShow" class="resize"/></div>
</template><script>export default {name: 'dragItem',props: {// 控制拖拽条的是否显示,默认显示resizeShow: {type: Boolean,default: true}}}
</script><style>.d-flex {min-width: 100px;height: 100%;position: relative;}.resize {position: absolute;top: 0;right: 0;width: 4px;height: 100%;cursor: col-resize;background: #e6e6e6;}
</style>

子2

<template><div ref='dragBox' class="dragBox"><slot></slot></div>
</template><script>export default {name: 'dragBox',data() {return {}},mounted() {this.setDragItemFlex()this.dragControllerDiv()},methods: {// 如果dragItem 没有定义宽度,则flex=1setDragItemFlex() {const dragBox = this.$refs.dragBoxconst childsLen = dragBox.children.lengthfor (let i = 0; i < childsLen; i++) {const node = dragBox.children[i]if (!node.style.width) {// 如果没有定义宽度,则flex=1node.style.flex = 1}}},dragControllerDiv() {const resize = document.getElementsByClassName('resize') // 拖拽条// 循环为每个拖拽条添加事件for (let i = 0; i < resize.length; i++) {// 鼠标按下事件resize[i].addEventListener('mousedown', this.onMouseDown)}},onMouseDown(e) {this.resizeBox = e.targetthis.currentBox = this.resizeBox.parentNode.parentNode// 当前盒子this.rightBox = this.getNextElement(this.currentBox)// 当前盒子的下个兄弟节点if (!this.rightBox) {return}this.curLen = this.currentBox.clientWidththis.otherBoxWidth = this.$refs.dragBox.clientWidth - this.currentBox.clientWidth - this.rightBox.clientWidth // 其他盒子的宽度// 颜色改变提醒// this.resizeBox.style.background = '#818181'this.startX = e.clientXdocument.addEventListener('mousemove', this.onMousemove)document.addEventListener('mouseup', this.onMouseup)},// 获取下一个兄弟元素的兼容函数getNextElement(element) {if (element.nextElementSibling) {return element.nextElementSibling} else {let next = element.nextSibling// 下一个兄弟节点while (next && next.nodeType !== 1) { // 有 并且 不是我想要的next = next.nextSibling}return next}},onMousemove(e) {const endX = e.clientXconst moveLen = endX - this.startX // (endx-startx)= 移动的距离const CurBoxLen = this.curLen + moveLen // resize[i].left+移动的距离=左边区域最后的宽度const rightBoxLen = this.$refs.dragBox.clientWidth - CurBoxLen - this.otherBoxWidth // 右侧宽度=总宽度-左侧宽度-其它盒子宽度// 当最小宽度时,无法继续拖动if (CurBoxLen <= 100 || rightBoxLen <= 100) {return}this.currentBox.style.width = CurBoxLen + 'px'// 当前盒子的宽度this.resizeBox.style.left = CurBoxLen // 设置左侧区域的宽度this.rightBox.style.width = rightBoxLen + 'px'},onMouseup() {// 颜色恢复//  this.resizeBox.style.background = '#d6d6d6'document.removeEventListener('mousedown', this.onMouseDown)document.removeEventListener('mousemove', this.onMousemove)}}}
</script><style scoped>.dragBox {width: 100%;height: 100%;display: flex;}
</style>
// 公共样式
/* 展开字体样式 */
.arrow-content {@apply text-base w-4 my-0 mx-auto pt-24
}/* 底部分页footer 样式 */.bottom-footer {@apply w-full flex items-center justify-between
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/247783.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Active MQ

转载于:https://www.cnblogs.com/ygl888/p/11020647.html

jQuery Ajax 实例

一、$.ajax的一般格式 $.ajax({ type: POST, url: url , data: data , success: success , dataType: dataType }); 二、$.ajax的参数描述 参数 描述 url 必需。规定把请求发送到哪个 URL。 data 可选。映射或字符串值。规定连同请求发送到服务器的数据。 success(data, textSt…

element ui封装 tree下拉框

展示&#xff1a; 子组件封装 <!-- 树状选择器 科室树形 --> <template><el-popoverref"popover"placement"bottom-start"trigger"click"show"onShowPopover"hide"onHidePopover"><el-treeref&quo…

Sitecore A / B测试

测试您的Web内容非常重要。这是查看页面中的页面和组件是否达到预期效果的好方法。测试还可以让您放心&#xff0c;您的内容足够吸引人&#xff0c;以增加转化次数并最大限度地提高增长率。 测试如何运作&#xff1f; 测试通过向访问者随机显示不同版本的内容来工作。Sitecore …

jQuery on()方法绑定动态元素的点击事件无响应的解决办法

$(#check_all).on(click , function(){ alert(1); }); $("#yujinlist").append(html); count; } 以上代码执行时&#xff0c;点击#check_all时&#xff0c;alert一直没反应&#xff0c;后在网上查资料时&#xff0c;才知道on前面的元素也必须在页面加载的时候就存在…

让数字保持在整数范围内

让数字保存在整数范围内 如&#xff1a; (1~10)之间的数取 10 (10~20)之间的数取 20 (20~30)之间的数取 30 let max (Math.round(数字/10)1)*10

UVA572 Oil Deposits DFS求解

小白书上经典DFS题目。 1. 递归实现 // from: https://www.cnblogs.com/huaszjh/p/4686092.html#include <stdio.h> #include <string.h> #define maxn 105 unsigned char data[maxn][maxn]; int m, n, vis[maxn][maxn];void dfs(int x, int y, int ans) {if (x &l…

HTML 表格中的行合并与列合并

colspan是横向合并&#xff1b;rowspan是纵向合并。colspan是“column span&#xff08;跨列&#xff09;”的缩写。colspan属性用在td标签中&#xff0c;用来指定单元格横向跨越的列数&#xff1a;单元格1 单元格2 单元格3 单元格4 该例通过把colspan设为“3”, 令所在单元格横…

java快速排序

package com.atguigu.java;/*** 快速排序* 通过一趟排序将待排序记录分割成独立的两部分&#xff0c;其中一部分记录的关键字均比另一部分关键字小&#xff0c;* 则分别对这两部分继续进行排序&#xff0c;直到整个序列有序。*/ public class QuickSort {private static void s…

网址备份

1.jstl标签库http://archive.apache.org/dist/jakarta/taglibs/standard/binaries/2.tomcat服务器http://tomcat.apache.org/3.mysql架包https://mvnrepository.com/4.jqueryhttps://github.com/jquery/jquery/releases5.图标http://icons8.com/preloaders6.jquery-formhttp://…

前端开发-热更新原理解读

- 一、websocket简介- 二、热跟新原理- 三、实例剖析- 四、总结websocket简介 在h5推出之前&#xff0c;浏览器应用跟服务器端通信的机制只有http协议&#xff0c;http是一种无状态的网络协议&#xff0c;前端向服务器发起一个请求&#xff0c;服务器给出一次应答&#xff…

java杨辉三角

package com.atguigu.exer; /** 使用二维数组打印一个 10 行杨辉三角。【提示】1. 第一行有 1 个元素, 第 n 行有 n 个元素2. 每一行的第一个元素和最后一个元素都是 13. 从第三行开始, 对于非第一个元素和最后一个元素的元素。即&#xff1a; yanghui[i][j] yanghui[i-1][j-1…

这65条工作和成长建议,你将受用终生!

这65条工作和成长建议&#xff0c;每一条都值得我们认真思考。希望对你有启发。 从1990年进入格力&#xff0c;董明珠已经工作了近30年。 她花了近30年的时间&#xff0c;一手把格力从一家亏损的中小企业变成全球500强&#xff0c;年销售额超过1400亿。 2004年&#xff0c;她被…

HTML5事件—visibilitychange 页面可见性改变事件

又看到一个很有意思的HTML5事件 visibilitychange事件是浏览器新添加的一个事件&#xff0c;当浏览器的某个标签页切换到后台&#xff0c;或从后台切换到前台时就会触发该消息&#xff0c;现在主流的浏览器都支持该消息了&#xff0c;例如Chrome, Firefox, IE10等。虽然这只是一…

java回型数

import java.util.Arrays;public class hello {public static void main(String[] args) {//输出5*5的int n 5;int [][] huizixingnew int[n][n];int minX0;//x轴最小下标int minY0;//y轴最小下标int maxXn-1;//x轴最大下标int maxYn-1;//y轴最大下标int counter0;//计数int xf…

用CSS3 vh 简单实现DIV全屏居中

vh、vw、vmin、vmax介绍 vw&#xff1a;视窗宽度的百分比&#xff08;1vw 代表视窗的宽度为 1%&#xff09;vh&#xff1a;视窗高度的百分比vmin&#xff1a;当前 vw 和 vh 中较小的一个值vmax&#xff1a;当前 vw 和 vh 中较大的一个值 浏览器兼容性 &#xff08;1&#xff09…

解决360等等浏览器兼容模式解析不兼容代码

之前写的代码不是很规范 , 在今天测试下发现360浏览器等等的浏览器使用兼容模式会有很多不兼容 , 网上了解过一下 , 说是很多浏览器的兼容模式可能就是为了兼容IE7之前的网站代码 , 而非我们字面理解的兼容二字 ... OK!跑题了 ... 我的解决方案是在页面head加<meta http…

java自定义异常报错

public class TeamException extends Exception{static final long serialVersionUID -3387516993124229948L;public TeamException() {super();}public TeamException(String message) {super(message);} }

P多行溢出省略号的处理

因为-webkit-line-clamp: 2不兼容火狐或IE&#xff0c;采用判断浏览器的方式来启用哪个方式先判断是什么浏览器 //判断是否是谷歌浏览器 if (!stripos($_SERVER["HTTP_USER_AGENT"], chrome)) {$this->registerCssFile(web/css/view.css); } 行内样式&#xff08;…

缩小窗口时CSS背景图出现右侧空白BUG的解决方法

页面容器&#xff08;#wrap&#xff09;与页面头部&#xff08;#header &#xff09;为100%宽度。而内容的容器&#xff08;#page&#xff09;为固定宽度960px。浏览窗口缩小而小于内容层宽度时会产生宽度理解上的差异。如下图所示窗口宽度大于内容层宽度&#xff1a; 改变浏览…