鸟食轩
Microsoft .NET[C#] MVP 2003
随笔 - 332, 文章 - 870, 评论 - 5722, 引用 - 356
从此不再为Web页面中的Tooltip烦恼
让Web页面中,不能折行或不希望被折行的文字始终显示在一行,是一种严格的UI风格,毕竟自由的折行会使得表格和整体界面变得很难把握。当然在一行显示不完全时配以省略号在结尾,能很好的提示用户表示语句未结束,不过这时为了让用户能看到所有文字,Tooltip就是必不可少的了。
显示Tooltip在Web上还不是轻而易举的事情,只要把html元素的title属性设上非空字符串,就自然是Tooltip了。不过这样其实还是挺麻烦的,由于预先写入title,会带来几个副作用:1、带来不必要的内容开销,因为预置title属性,会带来文档的增大;2、总是会显示Tooltip,即使在一行能显示完全的情况下,也显示Tooltip,这样就会让用户迷惑了,还以为再补充说明什么东西呢;3、遇到Tooltip需要显示的文字里有特殊字符,比如:单引号'双引号"时,还需要在服务器端对Tooltip内容编码。
使用客服端脚本来处理Tooltip,就可以避免上面提到的所有不足和问题。示例如下:
this is a long long long long long long long long long string.
this is a long long long long long long long long long string.
this is a long long long long long long long long long string.
this is a long long long long long long long long long string.
this is a long long long long long long long long long string.
this is a long long long long long long long long long string.
this is a long long long long long long long long long string.
this is a long long long long long long long long long string.
this is a long long long long long long long long long string.
this is a long long long long long long long long long string.
this is a long long long long long long long long long string.
this is a long long long long long long long long long string.
//
蓝色
的文字是自己本身就带有Tooltip的,你可以调整页面的大小看看Tooltip的适应性。
原理是在body元素上统一控制,把下面的代码手工加入页面底部,或者在ASP.NET中使用Page.RegisterStartupScript方法注册到页面上。
<
script
language
="javascript"
>
var
format
=
'
{
0
}
\r\n
{
1
}
';
document.body.onmouseover
=
function
()
{
var
srcElmt
=
event.srcElement;
if
( srcElmt
&&
srcElmt.tagName )
{
if
( srcElmt.clientWidth
<
srcElmt.scrollWidth )
{
if
(
!
srcElmt.__title )
{
if
( srcElmt.title
==
srcElmt.innerText )
{
return
;
}
if
( srcElmt.title )
{
srcElmt.__title
=
srcElmt.title;
}
}
else
{
return
;
}
if
( srcElmt.__title )
{
srcElmt.title
=
StringHelper.Format(format, srcElmt.__title, srcElmt.innerText);
}
else
{
srcElmt.title
=
srcElmt.innerText;
}
}
}
}
;
document.body.onmouseout
=
function
()
{
var
srcElmt
=
event.srcElement;
if
( srcElmt
&&
srcElmt.tagName )
{
if
( srcElmt.clientWidth
>=
srcElmt.scrollWidth )
{
if
( srcElmt.__title )
{
srcElmt.title
=
srcElmt.__title;
srcElmt.__title
=
null
;
}
else
{
if
( srcElmt.title
==
srcElmt.innerText )
{
srcElmt.title
=
'';
}
}
}
}
}
;
</
script
>
参数format用来控制当Tooltip重合的时候怎么显示,因为有的文字本身就有Tooltip,当它出现省略号的时候,就需要设计它怎么和自动的Tooltip一起显示。这样一来页面上只要使用css限制了单行的现实的文字,在出现省略号时就都自动的拥有了Tooltip,并且最重要的是,这时的Tooltip不会受任何特殊字符的影响哦
。
// StringHelper.Format 方法参看
这里
绿色通道:
好文要顶
关注我
收藏该文
与我联系
posted on 2005-09-01 23:48
birdshome
阅读(8484)
评论(9)
编辑
收藏
评论
793487
#1楼
回复
引用
查看
不错,呵呵
又学一招
2005-09-02 08:26
|
JustinLee
#2楼
回复
引用
太好了。
很有帮助。谢谢
2005-09-02 10:25
|
ncw[未注册用户]
#3楼
回复
引用
查看
俺先收藏起来
2005-09-02 11:03
|
徐灿钊Asp.net专栏
#4楼
回复
引用
谁知道firefox能不能弄出那种自动的"..."?!
2005-09-06 10:55
|
cnnwai[未注册用户]
#5楼
[
楼主
]
回复
引用
查看
在某些特定页面中,上面给出的代码可能有bug。修正版本如下:
var
format
=
'{
0
}\r\n{
1
}';
document.body.onmouseover
=
function
()
{
var
srcElmt
=
event.srcElement;
if
(
!
srcElmt.tagName
||
!
srcElmt.innerText
||
srcElmt.tagName
==
'BODY')
{
return
;
}
if
( srcElmt.offsetWidth
<
srcElmt.scrollWidth )
{
if
(
!
srcElmt.__title )
{
if
( srcElmt.title
==
srcElmt.innerText )
{
return
;
}
if
( srcElmt.title )
{
srcElmt.__title
=
srcElmt.title;
}
}
if
( srcElmt.__title )
{
srcElmt.title
=
StringHelper.Format(format, srcElmt.__title, srcElmt.innerText);
}
else
{
srcElmt.title
=
srcElmt.innerText;
}
}
else
{
if
( srcElmt.__title )
{
srcElmt.title
=
srcElmt.__title;
srcElmt.__title
=
null
;
}
else
{
if
( srcElmt.title
==
srcElmt.innerText )
{
srcElmt.title
=
'';
}
}
}
};
修正版只需要响应body的onmouseover一个事件就行了,其原因是onmouseover和onmouseout这两个看似配对的事件,并不能理想的配对被触发。由于窗口遮盖关系和鼠标移动速度等的影响,onmouseout事件的触发很不可靠,所以使用onmouseout清除或还原title的状态就是有很大缺陷的。同时修正版不使用onmouseout,也是少占用一个body对象的事件handler接口,而且可靠性大大加强,还可以对内容动态变化的字段进行正确的tooltip信息提示。
2005-09-07 13:59
|
birdshome
#6楼
回复
引用
firefox中不能正常省略啊
2005-09-18 14:12
|
zijie[未注册用户]
#7楼
回复
引用
查看
我正要找这个东西呢 呵呵
厉害呀。。。
2006-01-10 13:10
|
虫子的一天
#8楼
回复
引用
可惜要TABLE-LAYOUT: fixed;,这样的话所有列宽都是一样的,很多时候并不希望这样
2007-06-22 17:14
|
conch[未注册用户]
#9楼
[
楼主
]
回复
引用
查看
@conch
和table其实没有关系,更谈不上一定要table-layout:fixed,只是这个示例用了table而已。
2007-06-22 19:47
|
birdshome
注册用户登录后才能发表评论,请
登录
或
注册
,
返回博客园首页
。
首页
博问
闪存
新闻
园子
招聘
知识库
最新IT新闻
:
·
苹果征集iPad 3发布会演示应用 重点是图形应用
·
京东商城涉足汽车销售 将上线售车频道
·
亚马逊新广告挑衅苹果:一个iPad可买三台kindle
·
动视暴雪确认今年第二季度推出《暗黑破坏神3》
·
官方承认 Google Bar 逆行倒施
»
更多新闻...
最新知识库文章
:
·
如何学习一门新的编程语言?
·
学习不同编程语言的重要性
·
为什么我喜欢富于表达性的编程语言
·
计算机专业的女生为什么要学编程
·
前端必读:浏览器内部工作原理
»
更多知识库文章...
China-pub 2011秋季教材巡展
China-Pub 计算机绝版图书按需印刷服务
导航
博客园
首页
新随笔
联系
订阅
管理
公告
Invert
原创
技术文章和心得,
转载
必须注明来源
"博客园"
!
贴子以"现状"提供,且没有任何担保,同时也没有授予任何权利。
昵称:
birdshome
园龄:
7年10个月
荣誉:
推荐博客
粉丝:
73
关注:
3
搜索
常用链接
我的随笔
我的评论
我的参与
最新评论
我的标签
我的标签
Nokia 6300
(2)
fan
(1)
qq
(1)
腾讯
(1)
输入法
(1)
隐私
(1)
随笔分类
(337)
.NET的私有工具类(2)
(rss)
.NET技术开发相关(34)
(rss)
Asp.net控件开发(14)
(rss)
Debug中的滑铁卢(9)
(rss)
Enjoy Computer :)(27)
(rss)
Jscript&Dhtml开发(162)
(rss)
技术区里的非技术(49)
(rss)
开发中遇到的虫子(14)
(rss)
其它编程相关内容(16)
(rss)
商务智能(BI)开发(10)
(rss)
文章分类
(147)
北京的幸福生活(29)
(rss)
不得不转载(19)
(rss)
乖乖的文章(6)
(rss)
那时还没有blog(4)
(rss)
那是相当八卦(10)
(rss)
手机短信息(1)
(rss)
我们的文章(40)
(rss)
珍贵照片的背景(4)
(rss)
重庆的幸福生活(34)
(rss)
相册
2005 Kick Off @ 涞滩
2006 Kick Off @ 钓鱼城
2006 Offsite @ 四面山
2006 Wedding @ 昆明
2007 Marriage @ 哈尔滨
2007 Offsite @ Thailand
2007 Offsite @ 海南云天
2007 Training @ Seattle
2007 Travelling @ 云南
2008 Travelling @ 天津
乱七八糟的收集
Ex-Colleagues
Jason Lei's Space
.Net Life
(rss)
Jasper
(rss)
Michelles Space
xingd.net
(rss)
玻璃缸
(rss)
短鲷生活
海阔天空
录一室
(rss)
完美的泡菜
(rss)
怡红公子
(rss)
竹叶尖的BLOG
常用链接
Engadget 中文版
PDFCHM eBooks
SitePoint Forums
The Code Project
安利上海直销店
哈尔滨工业大学
哈工大紫丁香
海归论坛
(rss)
沙坪坝区中医院
兄弟情深
没有可乐的日子
葡萄树下不乘凉
(rss)
斯普特尼克
猪头小队长
(rss)
积分与排名
积分 - 3145044
排名 - 6
最新评论
阅读排行榜
推荐排行榜