js 实现 切分条效果, 为了熟悉js  写法,纯javascript 脚本编写

简单介绍几个函数:

setCapture()函数的作用就是将后续的mouse事件都发送给这个对象,

releaseCapture() 就是将鼠标事件还回去

由document、window、object之类的自行来处理,这样就保证了在拖动的过程中,不会由于经过了其它的元素而受到干扰。另外,还有一个很重 要的事情是,在Win32上,mouse move的事件不是一个连续的,也就是说,并不是我们每次移动1px的鼠标指针,就会发生一个mousemove,windows会周期性检查mouse的位置变化来产生mousemove的事件。所以,如果是一个很小的页面对象,比如一个直径5px的圆点,如果没有setCapture和releaseCapture,那么在鼠标按住之后,快速的移动鼠标,就有可能鼠标移动走了,但是小圆点还在原地,就是因为下一次的mousemove事 件已经不再发给这个圆点对象了。

var siblingElem = function (elem)
{
var _nodes = []; while ((elem = elem.previousSibling))
{
if (elem.nodeType === )
{ _nodes.push(elem); break; }
}
return _nodes[];
}
var nextElem = function (elem)
{
var _nodes = [];
while ((elem = elem.nextSibling))
{
if (elem.nodeType === )
{ _nodes.push(elem); break; }
}
return _nodes[];
}

获取相邻两个左右两个元素

为了方便运用编写一个js 对象

主要方法:根据鼠标移动的坐标计算左右两边容器的宽度

move = function (event, f)
{
if (f.flag)
{
if (f.iPner2With - event.clientX - f.ele.offsetWidth > )
{
f.objLeft.style.left = (event.clientX + f.ele.offsetWidth) + "px";
f.objRight.style.width = (f.iPner2With - event.clientX - f.ele.offsetWidth) + "px";
f.objLeft.style.width = event.clientX + "px"; }
if (!f.ele.releaseCapture)
{
event.preventDefault();
}
}
}
/****************************************

@Name:LR_spliter 实现table 和div 分割条效果
@Author:胡泽云
@Date:2014-08-27
@邮箱:hzeyun@sina.com
@qq:984559465
@说明: 实例化 new LR_spliter("控件id") */
var siblingElem = function (elem)
{
var _nodes = []; while ((elem = elem.previousSibling))
{
if (elem.nodeType === )
{ _nodes.push(elem); break; }
}
return _nodes[];
}
var nextElem = function (elem)
{
var _nodes = [];
while ((elem = elem.nextSibling))
{
if (elem.nodeType === )
{ _nodes.push(elem); break; }
}
return _nodes[];
}
zy_spliter = function (id)
{
this.flag = false;
this.objSplitter = false;
this.iPner2With = ; //获取对象的左右连个容器
this.ele = document.getElementById(id);
this.objLeft = siblingElem(this.ele);
this.objRight = nextElem(this.ele);
this.ele.style.cursor = "w-resize"; //设置鼠标样式
up = function (event, t)
{
if (t.flag)
{
if (t.ele.releaseCapture)
{
t.ele.releaseCapture();
}
else
{
document.removeEventListener('mouseup', t.up, true);
document.removeEventListener('mousemove', t.move, true);
event.preventDefault();
} t.flag = false;
}
};
down = function (event, f)
{ if (!f.flag)
{
if (f.ele.setCapture)
f.ele.setCapture();
else
{
document.addEventListener('mouseup', up, true);
document.addEventListener('mousemove', move, true);
event.preventDefault();
} f.flag = true; if (f.ele.parentNode.tagName == "TD")
{
f.iPner2With = f.ele.parentNode.parentNode.offsetWidth;
}
else
{
f.iPner2With = f.ele.parentNode.offsetWidth;
} }
};
move = function (event, f)
{ if (f.flag)
{ if (f.iPner2With - event.clientX - f.ele.offsetWidth > )
{
f.objLeft.style.left = (event.clientX + f.ele.offsetWidth) + "px";
f.objRight.style.width = (f.iPner2With - event.clientX - f.ele.offsetWidth) + "px";
f.objLeft.style.width = event.clientX + "px";
}
if (!f.ele.releaseCapture)
{
event.preventDefault();
}
}
}
var t = this;
this.ele.onmousedown = function ()
{
down(event, t);
} this.ele.onmouseup = function ()
{
up(event, t);
} this.ele.onmousemove = function ()
{
move(event, t);
}
return this; }

所有代码

实现效果: 第一种左右两边容器是div  , 第二种 是分割table 单元格的效果

前台html

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <script type="text/javascript" src="../Js/zeyun_spliter.js"></script>
    <script type="text/javascript">
        window.onload = function ()
        {
            var lsp = new zy_spliter("soliterSS");
            var lsp2 = new zy_spliter("sp2");
        }
       
    </script>
</head>
<body>
    <div style="height: 100px; width: 900px;">
        <div style="width: 450px; float: left; background: red; height: 100%; word-break: break-all;
            word-wrap: break-word;">
            asdsdf
        </div>
        <div id="soliterSS" style="width: 4px; height: 100%; float: left; ">
        </div>
        <div style="width: 442px; float: left; background: blue; height: 100%; position: relative;
            word-break: break-all; word-wrap: break-word;">
            adsfadsfjkl</div>
    </div>
    <p> table</p>
    <table style="height: 100px; width: 900px;" cellspacing="0" cellpadding="0">
        <tr>
            <td style="">
            </td>
            <td id="sp2" style="width: 4px; height: 100%; ">
                <div style="height: 100%;">
                </div>
            </td>
            <td style="">
            </td>
        </tr>
    </table>
</body>
</html>

js 实现分割条的更多相关文章

  1. 随笔 JS 字符串 分割成字符串数组 并动态添加到指定ID的DOM 里

    JS /* * 字符串 分割成字符串数组 并动态添加到指定ID的DOM 里 * @id 要插入到DOM元素的ID * * 输入值为图片URL 字符串 * */ function addImages(i ...

  2. js 字符串分割成字符串数组 遍历数组插入指定DOM里 原生JS效果

    使用的TP3.2 JS字符串分割成字符串数组 var images='{$content.pictureurl} ' ;结构是这样 attachment/picture/uploadify/20141 ...

  3. iOS8 UITableView 分割条设置separator intent = 0 不起作用

    转自:http://blog.csdn.net/ljb_wh/article/details/40788333 ios7的时候在storyboard 设置 TableView的separator in ...

  4. delphi如何加上spliter分割条,任意调整大小

    如题1:如何把一个panel分割成四个小的panle 2:也就是如何加上spliter,分割条,任意调整大小 3.如何有独立的handle使用多个总共5个为什么呢,你放4个panel 然后放split ...

  5. nprogress.js 头部进度条使用方法

    nprogress.js 头部进度条 引入CSS\JS <link rel="stylesheet" type="text/css" href=" ...

  6. js 实现进度条功能。

    /** * 纯js进度条 * Created by kiner on 15/3/22. */ function progress(options){ this.w = (options &&a ...

  7. three.js 显示一条线

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  8. Js 百分比进度条

    [构想] CSS3 + JS CSS3控制进度 利用CSS3中的 @keyframes JS实现百分比 根据CSS来调整,时间 [页面代码] 第一种: 默认直接进入就是下载 CSS代码 body { ...

  9. js加载条

    <html xmlns="http://www.w3.org/1999/xhtml"><head>    <meta http-equiv=" ...

随机推荐

  1. (转载)教你在PHP中使用全局变量

    (转载)http://www.chinaz.com/program/2009/0123/64261.shtml 即使开发一个新的大型PHP程序,你也不可避免的要使用到全局数据,因为有些数据是需要用到你 ...

  2. 动态规划 计数型DP:dobra

    令人愉快的单词(dobra)时间限制: 0.1 秒空间限制: 32 MB [问题描述]Lea 在她的一生中碰到过很多单词.其中的很大一部分都使她不愉快.作为补偿,她开始创造一些愉快的单词. Lea 通 ...

  3. 【字符串】【最小表示法】Vijos P1683 有根树的同构问题

    题目链接: https://vijos.org/p/1683 题目大意: 给M棵树,每棵N个点,N-1条边,树边有向,问哪些树同构. 题目思路: [字符串][最小表示法] 用()表示一个节点,那么三个 ...

  4. oracle 表查询(1)

    oracle 表基本查询 介绍在我们讲解的过程中我们利用scott 用户存在的几张表(emp,dept)为大家演示如何使用select语句,select 语句在软件编程中非常有用,希望大家好好的掌握. ...

  5. 常考的算法及Java知识总结

    算法 1 字符串模式匹配问题 2 排列组合问题 3 查找排序问题 数据结构 B树(B,B*,B+,红黑树)和二叉树的区别,MAP,hashmap, JAVA: 线程sleep,wait,wake(), ...

  6. CodeForces 220(div 2)

    悲剧的div2..... A 题意:在n * m的矩形平面直角坐标系中,从(x, y)可以到四个点(x - a, y - b),(x + a, y - b),(x - a, y + b),(x + a ...

  7. 拥有最小高度能自适应高度,IE、FF全兼容的div设置

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" " http://www.w3.org/TR/xh ...

  8. 【索引】Volume 0. Getting Started

    AOAPC I: Beginning Algorithm Contests (Rujia Liu) Volume 0. Getting Started 10055 - Hashmat the Brav ...

  9. README 语法编写

    推荐一个超棒的软件 haroopad Standard Markdown \ backslash ` backtick * asterisk _ underscore {} curly braces ...

  10. python通过SMTP发送邮件失败,报错505/535

    python通过SMTP发送邮件失败:错误1:smtplib.SMTPAuthenticationError: (550, b'User has no permission')    我们使用pyth ...