`
happmaoo
  • 浏览: 4543890 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

用DHTML整饰Form中的必填和非必填字段项

阅读更多

小说明:

这篇译文的英文题目是Trimming Form fields,上面的中文译题可能不是很贴切。

序:

web开发中Form经常被用来收集用户的一些信息,由用户在Form中输入一些基本的必填信息,当然包括你可以填写或可以不填写的非必填信息。

许多web商务站点的Form中通常会包含许多冗长和繁杂的各种字段项(与特定信息相关的文本框,下拉选择菜单,单选、多选按钮等HTML标记元素),由用户来填写或选择,一个不愿看到的事实是:这将严重影响电子商务的销售量- 大多数用户不会填写这些杂乱无章的字段项,而选择离开。

如果由用户来控制显示或隐藏那些非必填的字段项,将是一个非常好的主意!

怎么做?非常简单 仅用少量的JavascriptDOMCSS就能轻松完成。

n HTML标记

首先,我们设置一个基本的FormHTML代码如下,在Form中包含了fieldsetslegendslabels及一些HTML标记。

你将注意到每个字段项元素的后面都添加了<br/>标记,这里纯粹是为了页面布局,如果你不考虑布局效果可以把它删除。

n 绑定非必填字段项

需要被绑定的非必填字段项以及相关的label被放入div标记块中,并设置divclass属性名为“fm-optional”,代码如下:

现在,我们添加一个空段落放在Form上面,过一会它将成为显示/隐藏非必填字段项的一个开关:

n FormCSS设定

下面的CSS设定将适用于所有必填字段项。(所有字段都被指定为必填,除非另外设定-见后文)

其中,inputselect的外边线颜色被设为红色。

fieldset div {
margin : 0;

padding : 0;

}

fieldset div input {

width: 200px;

border : 1px solid #900;

padding : 1px;

}

fieldset div select {

width: 200px;

border : 1px solid #900;

padding : 1px;

}


为了进一步告知用户哪些是必填的字段项,在CSS中为label标记添加一个before伪类,它不适用于IE,见下面的代码:

fieldset div label:before {

content: "* "; // 在label前加一个*号,表示是必填字段项

}

现在,我们设置非必选字段项的样式(还记得前面有关非必填字段项的设置吗?div的class属性值是fm-optional,且这个div中包含的是非必填字段项。),这里input的外边线表现为灰色:

fieldset div.fm-optional {

display : block; /* 默认显示非必填字段项 */

}

fieldset div.fm-optional label:before {

content: ""; /* 移除label前的*号 */
}

.fm-optional input {
border : 1px solid #ccc; }

Form中所有样式设毕,当然,上面只是样式的一种方案,你可以自定义更贴切自已需要的。

n 添加事件

还记得吗?在开始时我们在Form上放置了一个id属性值为linkContainer的空段落。现在,我们要写一点Javascript并结合DOM对这个段落标记作一些操作,当html页面加载时,段落标记中生成一个超链接文本:


toggle.appendChild(document.createTextNode('要隐藏非必填字段项吗?'));



然后,当用户点击这个超链接文本后,会有一些文字上的变化:


this.firstChild.nodeValue = (linkText == '要隐藏非必填字段项吗?') ?

'
要显示非必填字段项吗?' : '要隐藏非必填字段项吗?';



最后,还要设置所有class属性值为fm-optional标记的样式:


if(tmp[i].className == 'fm-optional')

{

tmp[i].style.display = (tmp[i].style.display == 'none')

? 'block' : 'none';

}

n 小结

瞧!一个非常易于使用和理解(它甚至在JAWS上工作得非常好)的Form就做好了,用户只需要开关显示/隐藏非必填的字段,能够很快地在线处理那些必需填写的字段项。

下面是已经完成的一个示例:

http://blog.csdn.net/yjgx007/archive/2004/07/10/38273.aspx

下载示例中的css和js代码

分享到:
评论

相关推荐

    DHTML 默认行为中文手册

    6. **浏览器兼容性**:由于不同的浏览器可能对DHTML有不同的实现,手册还会强调跨浏览器开发的策略,包括如何使用条件注释和JavaScript库(如jQuery)来处理兼容性问题。 7. **实例分析**:为了帮助读者更好地理解...

    DHTML中文参考手册

    DHTML手册可能会介绍如何创建、操作和动画化VML图形,以及如何与其他DHTML元素结合使用。 **命令标识符** 命令标识符可能是JavaScript中的一些常用函数或者API,用于执行特定任务,如导航、弹出对话框或控制页面...

    CSS+DHTML中文手册

    5. **Ajax**:虽然不是DHTML的一部分,但Ajax(异步JavaScript和XML)技术常常与DHTML一起使用,提供无需刷新页面即可获取和更新数据的能力。 这个压缩包包含了两份中文手册,"DHTML.chm"涵盖了DHTML的相关知识,而...

    DHTML手册 DHTML手册

    CSS在DHTML中扮演着重要角色,它负责定义元素的外观和布局。通过选择器和规则,我们可以改变HTML元素的颜色、大小、位置等属性。CSS3的引入带来了更多的动画和过渡效果,增强了DHTML的表现力。 JavaScript作为DHTML...

    DHTML 手册中文文档

    DHTML 完全手册 动态 HTML (DHTML) 对象模型参考 &lt;br&gt;DHTML 对象 DHTML 属性 DHTML 方法 DHTML 事件 DHTML 集合 HTML 参考 &lt;br&gt;HTML 元素 HTML 字符集 样式表(CSS)参考 &lt;br...

    DHTML中文文档 用户手册

    **DHTML中文文档用户手册** 是一份针对动态超文本标记语言(DHTML)技术的详细指南,旨在帮助用户深入理解和应用这一技术。DHTML是一种在Web页面上实现交互性和动态效果的技术,它结合了HTML、CSS、JavaScript以及...

    DHTML概念、核心和编程

    DHTML是一种结合了DOM、CSS和客户端脚本的网页开发技术,它赋予了网页动态的特性,让网页内容和布局可以随时间和用户交互而变化。DOM作为文档的编程接口,是DHTML的核心,允许程序直接操作和改变HTML结构。CSS-P则...

    DHTML源代码和效果

    在这个压缩包文件"**DHTML效果**"中,可能包含了各种使用DHTML技术实现的图片效果示例。这些效果可能包括: - 图片滑动展示:利用JavaScript和CSS实现图片的自动轮播,或者通过用户点击按钮进行手动切换。 - 图片...

    DHTML 手册 DHTML 手册

    在DHTML中,CSS可以实现动态效果,如动画、过渡和变形,让元素在页面上以各种方式移动、改变大小或改变颜色,为用户提供视觉上的吸引力。 **JavaScript** JavaScript 是一种脚本语言,它是实现DHTML动态功能的核心...

    DHTML中文帮助手册CHM格式

    这份DHTML中文手册对于初学者和有一定经验的开发者都是宝贵的参考资料,无论你是想了解DHTML的基本原理,还是寻求解决特定问题的方法,都能在这个手册中找到答案。通过深入学习和实践,你可以掌握创建动态、交互式...

    Dhtml手册(Dhtml手册.chm)

    本Dhtml手册.chm文件是一个关于DHTML的综合参考资料,对于想要深入了解和学习DHTML的开发者来说,是一份宝贵的资源。 1. **HTML基础**:DHTML建立在HTML的基础上,HTML是超文本标记语言,用于创建网页结构。DHTML...

    DHTML中文参考手册(CHM)

    **DHTML** 是在Web开发中用于描述页面元素如何动态更新和交互的技术。通过DHTML,开发者可以在不重新加载整个页面的情况下更改页面的部分内容,实现如动画、响应式交互和实时更新等功能。这一技术在网页游戏、数据...

    DHTML手册中文chm版下载

    帮助你进行动态的网页制作。。。网页制作完全手册下载 。。DHTML 对象 DHTML 属性 DHTML 方法 DHTML 事件 DHTML 集合 HTML 参考。。DHTML手册中文chm版下载

    Dhtml帮助文档 (Dhtml帮助文档)

    通过深入学习DHTML和DHTMLX Suite,开发者可以创建出具有高度交互性和用户体验的现代Web应用,而不必依赖于特定的浏览器插件或框架。DHTML技术的发展也为后来的Ajax(Asynchronous JavaScript and XML)和现代前端...

    DHTML 手册 中文版.zip

    通过深入学习这本**DHTML手册中文版**,开发者不仅可以理解DHTML的工作原理,还能学会如何在实际项目中应用这些技术,打造富有活力和互动性的网页。随着Web技术的不断发展,DHTML作为早期实现页面动态化的技术,虽然...

    DHTML用户界面,使用方便

    在这个名为“DHTML用户界面,使用方便”的主题中,我们主要探讨如何利用DHTML技术构建易于使用的界面。 首先,DHTML的核心在于其动态特性。通过JavaScript,我们可以编写脚本来改变HTML元素的位置、样式和内容,而...

    dhtml menu

    在网页设计中,DHTML菜单的优势在于其灵活性和跨平台兼容性。"DHTMLMenu"工具正是这样一种能够生成与各种主流浏览器兼容的菜单代码的解决方案。通过使用"DHTMLMenu",开发者可以快速构建出具有专业外观和功能的菜单...

    DHTML案例培训.pdf

    例如,在一个表单提交过程中,如果用户还没有填写完所有必填项,我们可能不希望表单被提交。这时就需要使用`preventDefault()`方法来阻止默认行为。 **2.4 示例代码:** ```javascript // 获取表单元素 var form =...

Global site tag (gtag.js) - Google Analytics