- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图通过任一方式拖动 Bootstrap 行中的列,以增量方式将其调整为各自的列大小。它们必须始终添加最多 12 列。
See an example of what I'm trying to achieve
我需要的最接近的例子在这里:http://jsfiddle.net/onigetoc/ag4mgpbs/但是,它们周围的列不会根据它们旁边的列调整大小。
我已经考虑过使用 [gridstack.js 来实现这一点,但我无法使用基本的 jQuery/jQuery UI 正确地添加或减去列的逻辑。
我确信我编写的代码方向错误,我无法弄清楚为什么列在我期望的时候没有相加,这可能与我发生的事件有关正在使用。
var oldColNum = 0;
var nextColFraction = 0;
$('.column').resizable({
handles: 'e',
containment: 'parent',
start: function (e, ui) {
var nextCol = $(this).nextAll('.column').get(0);
nextColFraction = $(nextCol).data('fraction');
$(this).closest('.row').find('.column').css("width", '');
},
resize: function (e, ui) {
// console.clear();
/**
* The Column currently being resized
*/
var thisCol = ui.element;
oldColNum = thisCol.data('fraction');
/**
* The parenting row
*/
var parentRow = thisCol.closest('.row');
/**
* The Other Columns
*/
var nextCol = thisCol.nextAll('.column').get(0);
var otherCols = parentRow.find('.column').not(thisCol);
var otherColFractions = [];
otherCols.each(function () {
otherColFractions.push($(this).data('fraction'));
});
var totalOtherFractions = otherColFractions.reduce(function(a, b) { return a + b }, 0);
/**
* Work out the percentage width it currently is
*/
var cellPercentWidth = (100 * thisCol.outerWidth() / parentRow.outerWidth());
/**
* Change the class to the one that best suits the current size
*/
var colNum = getClosest(gridSystem, cellPercentWidth);
console.log(colNum, ui.originalElement.data('fraction'));
if (colNum < ui.originalElement.data('fraction')) {
nextColFraction++;
$(nextCol).removeClass(bsClass)
.addClass('col-md-' + nextColFraction)
.attr('data-fraction', nextColFraction);
}
if (colNum > ui.originalElement.data('fraction')) {
nextColFraction--;
$(nextCol).removeClass(bsClass)
.addClass('col-md-' + nextColFraction)
.attr('data-fraction', nextColFraction);
}
thisCol.removeClass(bsClass)
.addClass('col-md-' + colNum)
.attr('data-fraction', colNum);
thisCol.css("width", '');
}
});
});
// Bootstrap grid system array
var gridSystem = [
{grid: 8.33333333, col: 1},
{grid: 16.66666667, col: 2},
{grid: 25, col: 3},
{grid: 33.33333333, col: 4},
{grid: 41.66666667, col: 5},
{grid: 50, col: 6},
{grid: 58.33333333, col: 7},
{grid: 66.66666667, col: 8},
{grid: 75, col: 9},
{grid: 83.33333333, col: 10},
{grid: 91.66666667, col: 11},
{grid: 100, col: 12}
];
// find the closest number from Bootstrap grid
function getClosest(arr, value) {
var closest, mindiff = null;
for (var i = 0; i < arr.length; ++i) {
var diff = Math.abs(arr[i].grid - value);
if (mindiff === null || diff < mindiff) {
// first value or trend decreasing
closest = i;
mindiff = diff;
} else {
return arr[closest]['col']; // col number
}
}
return null;
}
任何帮助将不胜感激。
最佳答案
您会找到它后面具有网格类的下一列,并从中删除一个。
$(function() {
var bsClass = "col-sm-1 col-sm-2 col-sm-3 col-sm-4 col-sm-5 col-sm-6 col-sm-7 col-sm-8 col-sm-9 col-sm-10 col-sm-11 col-sm-12";
$(document).ready(function() {
$('.mb-grid-item').resizable({
handles: "e",
resize: function(e, ui) {
console.log('resizable');
var thiscol = $(this);
var currentNumberBefore = parseInt(thiscol.attr('class').match(/col-sm-(\d+)/)[1]);
var container = thiscol.parent();
var cellPercentWidth = 100 * ui.originalElement.outerWidth() / container.innerWidth();
// ui.originalElement.css('width', cellPercentWidth + '%');
var newColNum = getClosest(gridsystem, cellPercentWidth);
var thiscol = $(this);
thiscol.css("width", '');
//thiscol.removeAttr("style");
thiscol.find(".showClass").text('col-sm-' + newColNum);
//alert(cellPercentWidth);
var currentTopPosition = thiscol.position().top
var nextColumn = thiscol.next('.mb-grid-item');
var nextTopPosition = nextColumn.position().top;
if(currentNumberBefore !== newColNum && nextColumn && nextTopPosition === currentTopPosition) {
try {
var nextNumber = nextColumn.attr('class').match(/col-sm-(\d+)/)[1];
if(nextNumber) {
nextNumber = parseInt(nextNumber);
if((nextNumber+1) > 0) {
nextColumn.removeClass(bsClass);
var nextColumnNumber
if(currentNumberBefore > newColNum) {
nextColumnNumber = nextNumber+1;
} else {
if(nextNumber-1 > 0) {
nextColumnNumber = nextNumber-1;
} else {
nextColumnNumber = nextNumber;
}
}
var nextClass = 'col-sm-' + nextColumnNumber.toString();
nextColumn.find(".showClass").text(nextClass);
nextColumn.addClass(nextClass);
}
}
} catch(err) {
console.log('err', err);
}
}
thiscol.removeClass(bsClass).addClass('col-sm-' + newColNum);
}
}
);
}); //ready end
});
/***********************/
// Bootstrap grid system array
var gridsystem = [{
grid: 8.33333333,
col: 1
}, {
grid: 16.66666667,
col: 2
}, {
grid: 25,
col: 3
}, {
grid: 33.33333333,
col: 4
}, {
grid: 41.66666667,
col: 5
}, {
grid: 50,
col: 6
}, {
grid: 58.33333333,
col: 7
}, {
grid: 66.66666667,
col: 8
}, {
grid: 75,
col: 9
}, {
grid: 83.33333333,
col: 10
}, {
grid: 100,
col: 11
}, {
grid: 91.66666667,
col: 12
}, {
grid: 10000,
col: 10000
}];
// find the closest number from Bootstrap grid
function getClosest(arr, value) {
var closest, mindiff = null;
for (var i = 0; i < arr.length; ++i) {
var diff = Math.abs(arr[i].grid - value);
if (mindiff === null || diff < mindiff) {
// first value or trend decreasing
closest = i;
mindiff = diff;
} else {
// trend will increase from this point onwards
//return arr[closest]; //object
return arr[closest]['col']; // col number
//return arr[closest]['grid']; // col percentage
}
}
return null;
}
```
关于jquery - 拖动调整 Bootstrap 列大小 jQuery UI,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38945459/
我是 Javascript 新手,所以请原谅基本代码。有什么方法可以让我使用用户输入的指定调整来打印代码? height: width: 最佳答案 为按钮
我有一个带有 A 框架的场景,我正在使用方法 getCanvas 来获取屏幕截图并将其发送到 PHP。有没有办法调整 getCanvas 图像大小?因为默认的是 4096x2048,我需要它更小。如果
安排自动“分析表”的方法是什么。当大量数据通过插入和删除发生更改时,是否可以请求自动“分析表”?参数化自动分析表过程的方法是什么,即设置何时应该触发的规则。 最佳答案 您使用的是哪个版本的 Oracl
我只是想说,我是 C 语言的新手。好吧,除此之外,我在圣诞假期的任务是编写一个以各种方式操作 PNG 图像的程序。我已经完成了大部分事情,但是在尝试编写放大图像的程序时遇到了问题。我已经尝试过了,并且
在 Postgres 中编写更快查询的有效方法是什么?请不要包括一般良好的数据库实践(例如使用索引或规范化)。我正在寻找像派生表比子查询工作得更快或使用 python 字符串函数似乎比 pgsql 字
我不知道自己做了什么,但我要么将页眉和导航向右移动,要么将页面的其余部分向左移动。使用 tw Bootstrap 。我想不通。我对它进行了调试并查看了我的 css 编辑,没有看到任何负边距(我怀疑是这
我希望能够增加默认字体大小,但只能在特定的 DIV 内。 很明显,这似乎正是 ems 所针对的那种情况。我的问题是我只想增加字体大小,而不影响使用em设置大小的其他内容,例如填充和边距。 这可能看起来
我正在我的大学上数据挖掘类(class)。我真的不明白这个问题。谁能帮我理解一下? 最佳答案 重要性权重让您了解在采样时找到特定数据点的频率。您可以使用它来增加训练数据集。例如,如果您只有两个数据点:
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我的部分程序如下所示: char *argVector[] = {"./doTasks","0", "1", "3", NULL}; int numChild = 3; int temp; char
我在调整 QWindow 大小时观察到一个奇怪的行为。当我调整窗口大小时使宽度和高度都增加或减少时,窗口不会以白色背景闪烁。但是当我增加宽度同时减小高度(或反之亦然)时,窗口会闪烁并暂时用白色填充新的
我在使用 ggplot2 创建图形时遇到问题。我正在使用带有中心堆叠的 geom_dotplot 来显示我的数据,这些数据是 4 个类别的离散值。 出于审美原因,我想自定义点的位置,这样 沿 y 轴减
在尝试让我的 Canvas/Stage 调整大小并使其正确适合父容器时遇到一些问题。我发现了其他类似的帖子,虽然答案确实帮助我获得了新的屏幕尺寸,但它仍然不想适应容器,而是直接进入屏幕的边缘(这在示例
我想将路径大小调整为 20 像素左右。 SVG 的大小应为 500 * 500,现在路径宽度为 297,高度为 180.7。现在我需要这条路径,其宽度为 277,高度为 160.7,在之前的路径中。
我有一个矩形 svg,可以围绕二维平面拖动,围绕它自己的原点旋转并调整大小。 class SVG extends React.Component { constructor(props) {
我一直在尝试调整 MLP 模型的超参数来解决回归问题,但我总是收到收敛警告。 这是我的代码 def mlp_model(X, Y): estimator=MLPRegressor() param_gr
我正在创建一个聊天应用程序,我希望 ScrollView 的内容位于输入字段下方(向上滚动时)。我已经将 ScrollView 和输入字段放在 ZStack 中。 ScrollView 上的底部填充使
我遇到 GC 来不及删除空闲对象的情况。该代码将一个大文档加载到内存中并循环处理它。如果我在此循环中停止(在 Debug模式下)或添加 GC.Collect(),内存使用量将下降到 70 MB 以下。
我正在使用 iTextSharp 和 PdfSharp 的组合来组装一个大型 PDF 文件,以便打印到 Canon Oce VarioPrint 6000 系列打印机。 PDF 正在替换后记文件。 这
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我是一名优秀的程序员,十分优秀!