如何双向扩展元素宽度

How to extend element width both ways?

本文关键字:元素 扩展 何双      更新时间:2023-09-26

这个标题听起来令人困惑吗?我想无论如何都可能很好。

当我的人点击页面时,我希望他们能够让我更短和更长。

你可以在这里明白我的意思:

http://jsfiddle.net/shawn31313/HKLhE/9/show/

执行鼠标向下操作,它们会将您的移动向右移动。它工作正常。但是现在,将鼠标向左移动。看到问题了吗?它的方向与向右拖动时的方向相同。我知道这是因为我正在使用宽度,显然宽度是单向的。

这是我到目前为止的代码:

$(document).ready(function() {
    var dragStatus = 0,
        getPos, giveRandomID;
    $(document).mousedown(function(event) {
        dragStatus = 0;
        getPos = {
            top: event.clientY,
            left: event.clientX
        };
        giveRandomID = Math.floor(Math.random() * 99999);
    });
    $(document).mousemove(function() {
        var line = $('#line' + giveRandomID);
        if (dragStatus == 0) {
            $('body').append("<div id='line" + giveRandomID + "' class='line' style='position:absolute;top:" + getPos.top + "px;left:" + getPos.left + "px;background:black;width:2px;height:5px'></div>");
            dragStatus = 1;
        }
        if (dragStatus == 1) {
            if (event.clientX > line.offset().left) {
                line.css({
                    width: event.clientX - line.offset().left
                });
            } else {
                line.css({
                    width: line.offset().left - event.clientX
                });
            }
            //for DEG  "-" Top-Math.abs(DEG*2) for Deg "+" Top+(DEG*2)
        }
    });
    $(document).mouseup(function() {
        dragStatus = 2;
    });
});​

我希望有人可以帮助我解决这个问题。也许是一种完全不同的设置方式。只是解决这个问题的东西

若要使线条向左延伸,必须更新 left 属性:

        if (event.clientX > getPos.left) {
            line.css({
                left: getPos.left,
                width: event.clientX - getPos.left
            });
        } else {
            line.css({
                left: event.clientX,
                width: getPos.left - event.clientX
            });
        }

jsFiddle: http://jsfiddle.net/HKLhE/16/

您需要

修改else大小写(向右移动)以将left属性设置为 auto,将 right 属性设置为初始鼠标单击 X 位置。与offset().left相比,向左移动不起作用,因为该值正在发生变化。

试试这个尺寸:

http://jsfiddle.net/HKLhE/20/

编辑:Brilliand的解决方案更加优雅。