以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.net/bbs/index.asp)
--  专家坐堂  (http://foxtable.net/bbs/list.asp?boardid=2)
----  [求助]列的內容  (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=85721)

--  作者:PeterGu
--  发布时间:2016/6/1 18:27:00
--  [求助]列的內容
現有一想法,假設表A列B的列寬是一個值,而表A有好幾行,而每一行屬於列B的內容可能長,也可能短。
當一眼望去,想要一眼就看出哪一行屬於列B的內容已經超出列B的列寬,比如超出列寬的單元格背景為紅色。
請問有代碼能實現嗎?

--  作者:大红袍
--  发布时间:2016/6/2 1:04:00
--  

 你不就是可以看到全部的值吗?设置成自动列宽,或者自动行高,不就行了么?

 

 http://www.foxtable.com/help/topics/1669.htm

 


--  作者:大红袍
--  发布时间:2016/6/2 1:11:00
--  

 如果要设置,可以判断字符的长度,比如超过7个字符,就显示红色,可以这样写代码

 

 DrawCell事件

 

If e.Col.name = "第二列" Then
    e.Table.DataTable.AddUserStyle("样式1", Color.Red, Color.Black)
    If Encoding.Default.GetBytes(e.text).length >= 8*2-1 Then
        e.style = "样式1"
    End If
End If


--  作者:PeterGu
--  发布时间:2016/6/2 10:24:00
--  
感謝老師的回覆,我知道這個邏輯很奇怪,但是遇到客戶真的有這方面的要求
實際情況是這樣的:再查看某個表的時候,不會每次都去自動列寬(就算每次都去自動列寬,因為某些原因,這樣做也不整齊),一些已經超出列寬的訊息,有時候因為眼睛快速的掃過,會漏看一些被列寬設置遮蔽住的訊息。
所以才會有此一問,與其"仔細"的去察看文字在固定列寬下是否還有沒看到的訊息,不如利用單元格的背景顏色去很容易的區分。

--  作者:大红袍
--  发布时间:2016/6/2 10:27:00
--  

 你设置自动行高不就行了,全部内容显示了。

 

 好好看2、3楼。