This Domain(Admin5.com) is for Sale:

利用JavaScript创建功能强大的GUI

时间:2007-12-27  来源:不详  作者:林子


function insert_link() {
var str = document.selection.createRange().text;
document.my_form.my_textarea.focus();
var my_link = prompt("Enter URL:","http://");
if (my_link != null) {
var sel = document.selection.createRange();
sel.text = "<a href=\"" my_link "\">" str "</a>";
}
return;
} 本文来自织梦

  第二个函数insert_link()与format_sel()是相同的,加上prompt(),它们可以使用户输入一个超文本链接的值。使用prompt()的结果,我们可以将选定的文本和代码组合起来,创建一个连接。有了这些函数,我们就可以为用户创建所有类型的界面。下面我们来看一个例子。

copyright dedecms

在CSS中使用系统颜色

dedecms.com

  在网站上使用上面函数的最简单的方法就是在“bold”、“italic”、和“link”按钮的onclick事件处理程序中调用这些函数,但这不够刺激。由于我们使用了selection对象,把自己限定在了IE/Win平台上,我们就应该充分利用IE的特性,在CSS中使用用户定义的系统颜色,创建象我们在其他软件中看到的那样的动态按钮。下面我们首先来看看定义了工具栏、按钮、升起和按下二种按钮的状态的样式表。

本文来自织梦

#toolbar {
margin: 0;
padding: 0;
width: 262px;
background: buttonface;
border-top: 1px solid buttonhighlight;
border-left: 1px solid buttonhighlight;
border-bottom: 1px solid buttonshadow;
border-right: 1px solid buttonshadow;
text-align:right;
}

织梦好,好织梦

.button {
background: buttonface;
border: 1px solid buttonface;
margin: 1;
} 本文来自织梦

.raised {
border-top: 1px solid buttonhighlight;
border-left: 1px solid buttonhighlight;
border-bottom: 1px solid buttonshadow;
border-right: 1px solid buttonshadow;
background: buttonface;
margin: 1;
}

dedecms.com

.pressed {
border-top: 1px solid buttonshadow;
border-left: 1px solid buttonshadow;
border-bottom: 1px solid buttonhighlight;
border-right: 1px solid buttonhighlight;
background: buttonface;
margin: 1;
} 织梦内容管理系统

  读者可能已经注重到,我们在样式表中使用了三种系统颜色引用:buttonface、buttonshadow和buttonhighlight。通过将buttonface作为工具栏和按钮的背景色,我们可以使用用户得到与其他应用软件相同的界面外观。用buttonshadow和buttonhighlight色创建边界,通过编写简单的javascript函数,就能使按钮具有3D效果。当然,假如想使该GUI更与网站而不是用户的浏览器匹配,可以更换适当的颜色。

内容来自dedecms

  能够改变按钮样式的javascript下面的四个函数供事件处理程序在改变鼠标事件图像的类名时使用。尽管可以把javascript代码编写成嵌入式的,但我们把它们组织进一个函数中,方便以后添加其他功能。 dedecms.com

function mouseover(el) {
el.className = "raised";
} dedecms.com

function mouseout(el) {
el.className = "button";
}

dedecms.com

function mousedown(el) {
el.className = "pressed";
} 织梦内容管理系统

function mouseup(el) {
el.className = "raised";
}

本文来自织梦

与HTML进行整合 织梦好,好织梦

  现在剩下的工作就是将这些函数与包含工具栏、图像、文本域的HTML代码组合在一起: 织梦内容管理系统


class="button"
onmouseover="mouseover(this);"
onmouseout="mouseout(this);"
onmousedown="mousedown(this);"
onmouseup="mouseup(this);"
onclick="format_sel('b');"
src="bold.gif"

看完这篇,您有何感觉呢?

文章评论

共有位Admini5网友发表了评论 查看完整内容

24小时热门信息