Цитата:
|
Цитата:
|
devote,
Что ты так кипятишься? Тебе дизайнер сказал написать скрипт вычисляющий количество строк? Вариант с разворотом по more обрезающий по количеству символов куда короче и дизайн не измениться. Моё мнение лишь, что ты написал скрипт делающий сложно, то что можно делать просто. И второй блок у тебя до сих пор разваливается, так что дизайнер тебе его всё равно не зачтёт. Я привел лишь часто встречающуюся ситуацию из жизни, которую ты проигнорировал. Нет так нет, доказывать не нужно, я всё равно не пойму. А так да, идея забавная. |
Цитата:
|
Цитата:
|
Цитата:
|
блок с оверфлов: хидден можно прокручивать и без скролла. например выделением текста или кнопкой таб если есть элементы типо: а, инпут.
|
Цитата:
|
Цитата:
|
Цитата:
|
Я так понимаю мы говорим про абстрактный дизайн в вакууме. Я говорил только о том дизайне, который показал ТС в первом своем сообщении.
Я не против идеи скрипта, я против идеи решения подобных проблем таким способом. Мне он кажется слишком сложным для решения подобных задач. Для голого сайта идея может и сработать. Я не знаю, может и сработает, но я не стану тестить такой скрипт там, где без него обойтись проще, чем с ним. О чем вы говорите я вообще не понимаю. Цитата:
|
Пацан старался, зачет :)
Цитата:
|
ОлегА,
Не аргумент. Ты чей-то клон? А вот скрипт опять работает не так как предполагается: <div style="width: 200px; border: 1px solid #000;"> <div class="correct_comment">A<br>L<br>o<br>r<br>em ipsum dolor sit amet, consectetur adipiscing elit. Nulla tincidunt nunc commodo magna posuere sollicitudin. Quisque ultrices sodales nisi eu sagittis.</div> </div> С такой длинной скрипта, он по идее должен сам вычислять сколько строк должно помещаться в блок, а иначе я не вижу смысла, с количеством символов проще и короче. |
Цитата:
|
Gozar,
Ну понятно дело что в идеале на него нужно потратить каке-то время... что бы сделать его нормальным... Но нет у меня времени пока) |
devote,
Я никого не заставляю и не тороплю. Можешь вообще его не доделывать :) |
Цитата:
Цитата:
|
Простите, не могу создать тему, поэтому размщаю в этом сообщени, модераторам прошу перенести в новую тему.
Добрый вечер! После прочтения нескольких статей на этом сайте написал небольшую функцию для создания Drag And Drop блоков. Потестировал на прожорливость памяти и вот к каким резельтатам пришел: при создании 2000 блоков, съедается памяти Firefox 5mb - 11mb Opera -11mb Chrome -11mb Можно ли как-то оптимизировать скрипт, чтобы он ел меньше памяти? или совсем не ел. Функция предполагается использоваться на разных сайтах, чтобы было оптимизированно сразу. А то боюсь проблем в будущем. Спасибо за участие. Привожу сразу код, рабочий:
<html>
<body>
<script>
function leftTop (el) {
var left = 0;
var top = 0;
while (el.offsetParent){
left += el.offsetLeft;
top += el.offsetTop;
el = el.offsetParent;
}
left += el.offsetLeft;
top += el.offsetTop;
return {x:left, y:top};
}
function fixEvent (e) {
e = e || window.event;
if (e.pageX == null && e.clientX != null) {
var de = document.documentElement;
var body = document.body;
e.pageX = e.clientX + (de && de.scrollLeft || body && body.scrollLeft || 0) - (de.clientLeft || 0);
e.pageY = e.clientY + (de && de.scrollTop || body && body.scrollTop || 0) - (de.clientTop || 0);
}
if (!e.which && e.button) {
e.which = e.button & 1 ? 1 : (e.button & 2 ? 3 : (e.button & 4 ? 2 : 0));
}
return e;
}
function dd() {
var box;
var mouseOffset;
var posBlock;
var cacheX;
var cacheY;
var zIndex;
box = document.createElement('div');
box.style.width = '100px';
box.style.height = '100px';
box.style.border = '1px solid #000';
box.style.position = 'absolute';
box.onmousedown = function (event) {
zIndex = box.style.zIndex;
box.style.zIndex = 9999;
var e = fixEvent(event);
mouseOffset = (function (el, e){
var docPos = leftTop(el);
return { x:e.pageX - docPos.x, y:e.pageY - docPos.y };
})(box,e);
document.onmousemove = function (e) {
var e = fixEvent(e);
box.style.left = e.pageX - mouseOffset.x + 'px';
box.style.top = e.pageY - mouseOffset.y + 'px';
}
document.ondragstart = function() { return false };
document.body.onselectstart = function() { return false };
return false;
}
box.onmouseup = function () {
document.onmousemove = null;
document.onmouseup = null;
document.ondragstart = null;
document.body.onselectstart = null;
box.style.zIndex = zIndex;
box.style.cursor = 'default';
};
document.body.appendChild(box);
}
</script>
<body>
<script type="text/javascript">
for(var i = 0; i < 2000; i += 1){
dd();
}
// FF -5mb -11mb
// Opera -11mb
// Chrome -11mb
</script></body>
</html>
|
Gozar,
Да я как бы просто мимо пробегал):) |
Цитата:
|
Цитата:
|
yurik417,
ты год поста то посмотри, твой плагин куда позже появился. Может он и лучше, но тогда его не было. |
Цитата:
|
devote, хороший скрипт но к сожалению при уменьшении ширины окна браузера, и соответственно уменьшении ширины последнего дива, количество видимых строк хоть и сохраняется, но точки на обрезке исчезают.
В моём случае, который я изложил в этом посте: http://javascript.ru/forum/375522-post17.html клик раскрывающий полный текст не нужен. Гиперссылка, раскрывающая карточку товара, в которой есть полный текст обрезанного заголовка, уже существует. Необходимы лишь постоянно видимые точки на конце обрезки, информирующие посетителя о том что текст (заголовок) не полный и фиксированное количество строк не зависимое от ширины дива. Не могли бы вы высказать предположение, как решена задача по обрезке заголовков товаров на этой странице: http://www.obi.ru/decom/category/%D0...%8B%D0%B5/1064 Здесь заголовки обрезаются как нужно. То есть они в две строки с тремя точками по обрезке. И если плавно изменять ширину окна браузера, то дивы соответственно сужаются и количество знаков (буквально по буквам!) в их заголовках также меняется. Но две строки с тремя точками сохраняются чётко! В PHP насколько я знаю, функцией mb_substr() можно резать только по количеству заданных символов. В CSS адаптивная обрезка по границе дива с добавлением трёх точек получится, если добавить стиль: text-overflow: ellipsis; overflow: hidden; white-space: nowrap; Но к сожалению текст при этом становится однострочным. |
rikitiki,
ну нун перезапускать скрипт по onresize window, где-то сохраняя строку исходник (в принципе проблема решаема добавкой трёх строк при сохранением на sessionStorage) |
| Часовой пояс GMT +3, время: 08:10. |