2010-04-21 66 views
7

的意見,我想有這樣的消息編寫一個HTML表:需要與HTML表格

alt text http://img717.yfrog.com/img717/4348/tableo.png

該表將包含將分佈在第一N列(N可能會改變)消息。 讓我們調用這N列消息區域。 每條消息都位於消息區域中的X個連續單元上。 X也可能改變。

每條消息都有一個名稱,其中包含以下劃線分隔的單詞。

你會如何建議在Javascript/jQuery的實現代碼表這樣的:

  • 這將是容易定義消息(開始單元,結束單元格,顏色,名稱)
  • 名將只能在下劃線之後突破(而不是在字中間)

回答

5

線性地對單元格進行編號,將其轉換爲行/列,將範圍內的每個單元格的背景和邊框設置爲...不太難。

棘手的一點是,通過讓單元格的內容從單元格溢出來將文本插入頂部,因爲IE的表溢出會被竊聽到位。

這是我得到的似乎工作...它包含IE7的黑客,但我沒有在IE6上測試它,所以誰知道會發生什麼。

<style type="text/css"> 
    #t { table-layout: fixed; width: 50%; border-collapse: collapse; } 
    #t td { border: solid black 1px; height: 1.2em; overflow: visible; } 
    #t .message { text-align: center; } 

    /* these styles fix ie bugs */ 
    #t .message { position: relative; } 
    #t .message div { position: absolute; top: 0; left: 0; width: 100%; } 
</style> 

<table id="t"> 
    <tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr> 
    <tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr> 
    <tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr> 
    <tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr> 
    <tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr> 
    <tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr> 
    <tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr> 
    <tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr> 
    <tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr> 
    <tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr> 
    <tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr> 
    <tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr> 
</table> 

<script type="text/javascript"> 
    var t= new MessageTable(document.getElementById('t'), 3); 
    t.addMessage('SHORT_MESSAGE', 4, 16, 'yellow'); 
    t.addMessage('VERY_VERY_LONG_MESSAGE', 20, 14, 'cyan'); 

    function MessageTable(element, width) { 
     return {addMessage: function(text, c, n, color) { 
      // add zero-width spaces for breaking 
      text= text.replace(/_/g, '_\u200B'); 

      // set background and borders 
      for (var i= c; i<c+n; i++) { 
       var x= i%width, y= Math.floor(i/width); 
       var style= element.rows[y].cells[x].style; 
       style.backgroundColor= color; 
       style.borderLeftStyle= (i===c || x===0)? 'solid' : 'none'; 
       style.borderRightStyle= (i===c+n-1 || x===width-1)? 'solid' : 'none'; 
       style.borderTopStyle= i-c<width? 'solid' : 'none'; 
       style.borderBottomStyle= c+n-i<width? 'solid' : 'none'; 
      } 

      // add message to overflowing cell in first full row 
      // The do-nothing inner div is required for IE (again. bah) 
      var message= document.createElement('div'); 
      var inner= document.createElement('div'); 
      message.className= 'message'; 
      message.style.width= width+'00%'; 
      message.appendChild(inner); 
      inner.appendChild(document.createTextNode(text)); 
      element.rows[Math.ceil(c/width)].cells[0].appendChild(message); 
     }}; 
    } 
</script> 
+0

非常感謝您的代碼! 我試圖將消息區域更改爲6列,但似乎消息文本仍然在第3列中斷。那應該是這樣嗎? – 2010-04-21 13:26:07

+0

哦!是啊。這是樣式表中的'300%'。更新後從JavaScript爲了保持一致性而編寫該寬度。 – bobince 2010-04-21 15:26:43

+0

我在IE8上收到了'message.style.width = this.width + '00%';'''無效參數錯誤' – 2010-04-21 15:35:16