自定义表单——jQuery制作个性化Checkbox

要让表单中的元素具有个性化风格,仅仅通过样式来实现是相当困难的,大家都很清楚,每种内核的浏览器、每种系统平台下对form元素解析的风格都是不一致的。如果你想让form元素在各种平台或者说各种浏览器具有统一的样式风格,仅仅通过CSS来制作是很难达到统一的标准,但实现他也并不是一件很难的事情,你只要借助jQuery就能轻松的实现。那么今天开始一起来学习使用jQuery制作表单元素的系列,让你不在为此感到头痛。

今天我们就先来看第一个实例,这个实例是由Martin Angelov给我们带来的《Better Check Boxes with jQuery and CSS》。在这个简短的教程中,我们将一起学习如何通过jQuery来美化表单中的checkbox。只需要通过jQuery写一个插件,就可以按照自己的需求来更换浏览器默认的样式,但当用户不支持javaScript时,浏览器又能以默认的风格显示。具体效果如下面的DEMO所示:

HTML Markup

第一步你需要创建一个checkbox表单的HTML结构。以及需要创建另外一个替换默认checkbox表单的结构。

			<form action="./" method="post">
				<ul>
					<li>
						<label for="ch_effects">Display effects:</label>
						<input type="checkbox" id="ch_effects" name="ch_effects" data-on="show effects" data-off="hide effects" />
					</li>
					<li>
						<label for="ch_location">Enable Location tracking:</label>
						<input type="checkbox" id="ch_location" name="ch_location" checked="checked" />
					</li>
					<li>
						<label for="ch_showsearch">Include me in search results:</label>
						<input type="checkbox" id="ch_showsearch" name="ch_showsearch" />
					</li>
					<li>
						<label for="ch_email">Email notifications:</label>
						<input type="checkbox" id="ch_email" name="ch_emails" data-on="ON" data-off ="OFF" />
					</li>
				</ul>
			</form>
		

我们将复选框和描述文字都放在了列表中,从用户的交互点出发,我们点击label时能选中/取消选中相应的复选框。在HTML5中我们还可以使用“data”属性来指定一些label。在此例中我们使用了date-on和date-off用来设置选中/取消时的label。

上面的代码是默认表单的HTML,我们还需要一个新的HTML结构,主要用来更换默认复选框的HTML标记:

			<span class="tzCheckBox checked">
				<span class="tzCBContent">ON</span>
				<span class="tzCBPart"></span>
			</span>
		

当我们的插件调入进来后,他会遍历所有复选框,把上面的代码插入到复选框后面,并在同一时间把默认复选框隐藏。并使用.checked类来控制复选框是选中/取消状态。

CSS Code

首先简单的定义一下默认的表单样式。

			form ul {
				list-style: none;
			}
			
			form li {
				padding: 15px;
			}
			
			form li:nth-child(even) {
				background: #ccc;
			}
			
			form label {
				display: inline-block;
				color: #333;
				font-size: 20px;
			}
		

当然你可以根据你自己的需求进行更理想的样式设置。另外我们使用一张背景图片来修改替代默认复选框的样式,上面绿色部分是代表复选框选中状态,而下面红色部分代表复选框未选中状态,而且其宽度跟随说明文字自适应宽度。下图所示的就是复选框的样式所作的具体说明:

我们使用一个透明的PNG背景图片来修改替代默认复选框元素的样式,图片上半部分红色部分用来美化选中状态,而下面的大红色是用来美化取消状态,并且具有自适应宽度,下面我们来看看具体代码

jQuery.tzCheckbox.css

			/*==========jQuery.tzCheckbox.css==============*/
			.tzCheckBox{
				background:url('images/bg-tzcheckbox.png') no-repeat right bottom;
				display:inline-block;
				min-width:60px;
				height:33px;
				white-space:nowrap;
				position:relative;
				cursor:pointer;
				margin-left:14px;
			}
			.tzCheckBox.checked{
				background-position:top left;
				margin:0 14px 0 0;
			}
			.tzCheckBox .tzCBContent{
				color: white;
				line-height: 31px;
				padding-right: 38px;
				text-align: right;
			}
			.tzCheckBox.checked .tzCBContent{
				text-align:left;
				padding:0 0 0 38px;
			}
			.tzCBPart{
				background:url('images/bg-tzcheckbox.png') no-repeat left bottom;
				width:14px;
				position:absolute;
				top:0;
				left:-14px;
				height:33px;
				overflow: hidden;
				}
			.tzCheckBox.checked .tzCBPart{
				background-position:top right;
				left:auto;
				right:-14px;
			} 
		

jQuery Code

接下来我们用jQuery来创建一个tzCheckbox的插件。用来实现复选框的选中/取消功能。

			(function($){
				$.fn.tzCheckbox = function(options){
					//定义ON/OFF标签
					options = $.extend({
						labels: ['ON','OFF']
					},options);
					
					return this.each(function(){
						var originalCheckBox = $(this),
								labels = [];
						//检查data-on和data-off属性
						if(originalCheckBox.data('on')){
							labels[0] = originalCheckBox.data('on');
							labels[1] = originalCheckBox.data('off');
						} else {
							labels = options.labels;
						}
						
						//创建新的checkbox的html结构
						var checkBox = $('<span>',{
							class: 'tzCheckBox ' + (this.checked ? 'checked' : ''),//此处'tzCheckBox '需要加一个空格,不然会和checked连在一起
							html: '<span class="tzCBContent">' + labels[this.checked ? 0 : 1] + '</span><span class="tzCBPart"></span>'
						});
						
						//插入自定义的checkbox,并隐藏默认的Checkbox
						checkBox.insertAfter(originalCheckBox.hide());
							
						checkBox.click(function(){
							checkBox.toggleClass('checked');
							var isChecked = checkBox.hasClass('checked');
							//同步原复选框
							originalCheckBox.attr('checked',isChecked);
							checkBox.find('.tzCBContent').html(labels[isChecked ? 0 : 1]);
						});
						
						//监听改变原checkbox并同步新checkbox效果
						originalCheckBox.bind('change',function(){
							checkBox.click();
						});
					});
				}
			})(jQuery);
		

上面是今天的主要部分,没有这个插件我们的自定义checkbox就无法正常的工作。你可以将上面的代码单独的放在一个文件中,也可以放在你需要使用的页面中,我个人建议单独的使用一个文件,方便管理,就如此例,我将其命名jquery.tzCheckbox.js

在正式使用之前,我们需要将jquery版本库,和上面创建的插件一起调入到你的项目中

			<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.4/jquery.min.js"></script>
			<script type="text/javascript" src="js/jquery.tzCheckbox.js"<</script>
		

而且使用插件也是非常的容易的,只要在你需要使用的页面,并且你想自定义的checkbox上使用下面的一段jQuey代码:

			<script type="text/javascript">
				$(document).ready(function(){
					$('input[type=checkbox]').tzCheckbox({
						labels:['Enable','Disable']
					});
				});
			</script>
		

只要你选择了checkbox就会将“Enable”和“Disable”传递给“tzCheckbox”插件,用来代替默认文本。你也可以根据你自己的需要设置你想要的文本内容。这样我们的复选框自定义美化效果就完成了。如下面的DEMO所示。

当然大家可以根据自己的需求,改变样式风格。如果你对这种方法还有不清楚的地方,你可以直接点击Martin Angelov写的《Better Check Boxes with jQuery and CSS》,你也可以点击 这里下载源码自己学习。最后再次感谢Martin Angelov给我们带来这么好的教程《Better Check Boxes with jQuery and CSS》。

如需转载烦请注明出处:W3CPLUS

返回顶部