Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 22.09.2009, 17:26
Интересующийся
Отправить личное сообщение для alex.v Посмотреть профиль Найти все сообщения от alex.v
 
Регистрация: 22.09.2009
Сообщений: 11

свойства width и height в IE....
Доброго времени суток.

Мне нужно сделать функцию создания таблиц,
вот собственно функция(и), кроме всего прочего в шапке таблицы должны создаваться кнопки для возможности редактирования параметров самой таблицы(ну это лирика, важен факт наличия кнопок в хедере.)

*ОФФТОП* Заранее сорри за большое сообщение.

логика функции здесь :

this.addEmptyTable = function(dstTarget, rowNum, colNum, className, arrStylesTd, arrStyleTab) {
        var userAgent = "";
        if (navigator.userAgent.match('MSIE')) {
            userAgent = "ie";
        }
        var table, thead, tbody, tr, td, dragTr, saveLink;
        table = createElem("table", "contTab_" + id, dstTarget, arrStyleTab);
        thead = createElem("thead", "", table, null);
        dragTr = createElem("tr", "dragTr_" + id, thead, null);
        td = createElem("td", "", dragTr, new Array(new Array("height", "20px")));



        if (userAgent == "ie") { 
            var newElSaveLink = document.createElement("input");// вот эта самая кнопка в хедере
            newElSaveLink.id = id + "_editBut";
            newElSaveLink.type = "button";
            newElSaveLink.value = "Edit";
            newElSaveLink.style['cursor'] = "pointer";
            if (td) {
                td.appendChild(newElSaveLink);
            }
        }
        else {
            td.setAttribute("colspan", colNum);
            table.setAttribute("border", "2");
// вот эта самая кнопка в хедере
            saveLink = createElem("input", id + "_editBut", td, new Array(new Array("width", "50px"), new Array("cursor", "pointer")));
            document.getElementById(id + "_editBut").setAttribute("type", "button");
            document.getElementById(id + "_editBut").setAttribute("value", "Edit");
        }


        tbody = createElem("tbody", "", table, null);
        var counter = 1;
        for (var i = 0; i < rowNum; i++) {
            tr = createElem("tr", "", tbody);
            for (var j = 0; j < colNum; j++) {
                td = createElem("td", "contTd" + counter + "_" + id, tr, arrStylesTd);
                counter++;
            }
        }
        return table;
    }
}


далее сама функция которая создает и апендит то что мне надо:

var createElem = function(tagName, id, destTarget, arrStyles) {
        var newEl = document.createElement(tagName);
        newEl.id = id;
        var styleElem, styleValue;
        if (arrStyles && arrStyles.length > 0) {
            for (var i = 0; i < arrStyles.length; i++) {
                styleElem = arrStyles[i][0];
                styleValue = arrStyles[i][1];
                newEl.style[styleElem] = styleValue;
            }
        }
        if (destTarget) {
            destTarget.appendChild(newEl);
        }
        return newEl;
}


это преамбула.

вызываю функцию так:

stArTd = new Array(); // массив стилей для td
stArTd[0] = new Array("background", "red");
//stArTd[1] = new Array("width", "50px");
//stArTd[2] = new Array("height", "50px");


stArTab = new Array(); // массив стилей для table
stArTab[0] = new Array("position", "absolute");
stArTab[1] = new Array("top", "200px");
stArTab[2] = new Array("left", "200px");
stArTab[3] = new Array("width", "300px");
stArTab[4] = new Array("height", "300px");


var comT = new comTable(cCommon.GetGuid());

comT.addEmptyTable(document.getElementById(dropTarget), 3, 3, null, stArTd, stArTab); //вызывем функцию, на dropTarget не обращаем внимание, это то, куда таблица и апендится


Проблема в том, что если задавая параметры width и height самой таблицы (в массиве стилей stArTab) и при этом не задавая width и height для td (в массиве стилей stArTd), везде кроме IE создается и отрисовывается нормальная табличка, с пропорцианальными td-шками, т.е. равного размера ячейками,
в IE же, огромного размера thead в нем кнопка и малюсенькие ячейки самой таблицы.



если же задать width и height для td (закоментированные //stArTd[1] = new Array("width", "50px"); и //stArTd[2] = new Array("height", "50px"))

то все нормально



в чем проблема??

тяжело было все это описать, т.к. исходный код в разы больше и пришлось выдирать, поэтому если что-то непонятно, то пожалуйста спросите, я постраюсь объяснить.

любая критика по поводу кода и логики приветствуется, я пока еще нуП ))

Заранее спасибо!!!
Ответить с цитированием
  #2 (permalink)  
Старый 22.09.2009, 17:44
Новичок на форуме
Отправить личное сообщение для Kolyaj Посмотреть профиль Найти все сообщения от Kolyaj
 
Регистрация: 19.02.2008
Сообщений: 9,177

Сообщение от alex.v
в чем проблема??
И в чем проблема?
Ответить с цитированием
  #3 (permalink)  
Старый 23.09.2009, 08:41
Интересующийся
Отправить личное сообщение для alex.v Посмотреть профиль Найти все сообщения от alex.v
 
Регистрация: 22.09.2009
Сообщений: 11

проблема в том, что мне не надо задавать высоты и ширину для ячеек, надо только для таблицы.
Ответить с цитированием
  #4 (permalink)  
Старый 23.09.2009, 09:45
Новичок на форуме
Отправить личное сообщение для Kolyaj Посмотреть профиль Найти все сообщения от Kolyaj
 
Регистрация: 19.02.2008
Сообщений: 9,177

В процентах можно указать.
Ответить с цитированием
  #5 (permalink)  
Старый 23.09.2009, 10:44
Интересующийся
Отправить личное сообщение для alex.v Посмотреть профиль Найти все сообщения от alex.v
 
Регистрация: 22.09.2009
Сообщений: 11

Сообщение от Kolyaj
В процентах можно указать.
не пойдет.

в любом случае при фиксированной ширине и высоте таблицы, ячейки не будут иметь того процента который я укажу.в зависимости от их количества они будут иметь те размеры, чтобы уместиться в таблице.
Ответить с цитированием
  #6 (permalink)  
Старый 23.09.2009, 10:51
Новичок на форуме
Отправить личное сообщение для Kolyaj Посмотреть профиль Найти все сообщения от Kolyaj
 
Регистрация: 19.02.2008
Сообщений: 9,177

Сообщение от alex.v
ячейки не будут иметь того процента который я укажу.в зависимости от их количества они будут иметь те размеры, чтобы уместиться в таблице.
Че?
Ответить с цитированием
  #7 (permalink)  
Старый 23.09.2009, 12:44
Интересующийся
Отправить личное сообщение для alex.v Посмотреть профиль Найти все сообщения от alex.v
 
Регистрация: 22.09.2009
Сообщений: 11

а вот че:

пример

в моем случае получается так
Ответить с цитированием
  #8 (permalink)  
Старый 23.09.2009, 12:56
Новичок на форуме
Отправить личное сообщение для Kolyaj Посмотреть профиль Найти все сообщения от Kolyaj
 
Регистрация: 19.02.2008
Сообщений: 9,177

А зачем пяти ячейкам указывать высоту 50%?
Ответить с цитированием
  #9 (permalink)  
Старый 23.09.2009, 13:06
Интересующийся
Отправить личное сообщение для alex.v Посмотреть профиль Найти все сообщения от alex.v
 
Регистрация: 22.09.2009
Сообщений: 11

это я для примера показал, у меня один стиль ко всем ячейкам атачиться.
да вот в том-то и дело что мне не надо указывать размеры ячейки, но если не указывать,то и получается проблема в ie которая в картинках описана в первом сообщении.
Ответить с цитированием
  #10 (permalink)  
Старый 23.09.2009, 13:08
Новичок на форуме
Отправить личное сообщение для Kolyaj Посмотреть профиль Найти все сообщения от Kolyaj
 
Регистрация: 19.02.2008
Сообщений: 9,177

Если вы не указываете размеры, то браузер их может установить такими, какими считает нужным. Если указываете невозможные размеры, то же самое. У вас вопрос какой? Как заставить браузер догадываться, что вы от него хотите?
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Узнать Height всего открытого документа viod Events/DOM/Window 4 09.10.2008 13:07
Запретить свойства из CSS SunnyDay Общие вопросы Javascript 11 29.09.2008 14:30
Вызов скрипта для Opera Andrew_S Общие вопросы Javascript 8 25.09.2008 12:23
Создание закругленные края с резиной по weight и height baal1988 (X)HTML/CSS 0 02.09.2008 15:12
Неопределенное значение width. lancer Общие вопросы Javascript 3 03.04.2008 17:48