jquery插件开发尝试(二)

经过上次的尝试,已初步掌握jquery插件的写法,下面为模拟jquery UI插件的效果:

html:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8"/>
		<meta content="width=device-width, initial-scale=1.0,minimun-scale=1.0 maximum-scale=1.0, user-scalable=no" name="viewport"/>
		<meta name="apple-mobile-web-app-capable" content="yes">
		<meta name="apple-mobile-web-app-status-bar-style" content="black"/>
		<title>jquery menu插件demo</title>
		<link rel="stylesheet" href="../css/ljwCommon.css"/>
		<script src="../js/jquery.js"></script>
		<script src="../js/jquery.menu.js"></script><!--引入新写插件-->
	</head>
	<style>
		body{padding:0;margin:0;}
	       .wrap{padding:0;margin:0;}         ul{padding:0px;margin:0;}         .menuItem p{padding:0;margin:0;}         .menuItem{float: left;list-style: none;cursor: pointer;}         .subMenuItem{list-style: none;cursor: pointer;}
	</style>
	<body>
		<div class="wrap">
			<div class="header">

			</div>
		</div>
	</body>
	<script>
		$(function(){
			$(".header").menu({
				menuItem:[
				{menuTitle:‘首页‘},
				{ menuTitle:‘下拉‘,//菜单名
				  subMenuList:[‘下拉1‘,‘下拉2‘,‘下拉3‘] //子菜单
				}],
				MenuCss:{
					MTitleCss:{color:"red",padding:"5px 20px",backgroundColor:"#dedede"},  //设置菜单名样式
					SubMenuCss:{color:"blue",backgroundColor:"#f5f5f5",padding:"2px 20px",lineHeight:"1.5em"} //设置子菜单样式
				}

				});
		});
	</script>
</html>

jquery.menu.js:

/**
*menu插件
*生成节点
*为节点绑定时间
*参数defaults,包括
*menuItem数组,元素为json对象,json对象内含menuTitle 菜单名,subMenuList子菜单
*MenuCss json对象,内含MTitleCss菜单名css样式,SubMenuCss子菜单样式,
*/
;(function($){
	$.fn.menu = function(options){
		var menuLength = ‘‘,//菜单长度
			submenuLength = ‘‘,//对应子菜单长度
			MenuDom = ‘‘,//menu节点结构
			Item = 0,//用于遍历菜单长度
			SubItem = 0,//用于遍历子菜单长度
		    defaults = {
				menuItem : [{ menuTitle:"", subMenuList:[] }],
				MenuCss : {MTitleCss:{},SubMenuCss:{}}//menu节点样式
			};

		    defaults = $.extend(defaults,options);
		    /*********/

		    menuLength = defaults.menuItem.length;

		    for(Item = 0;Item < menuLength;Item++){

		    	if(defaults.menuItem[Item].subMenuList){
		    		submenuLength = defaults.menuItem[Item].subMenuList.length;
		    		MenuDom +="<li class=‘menuItem‘>"+"<p class=‘menuTitle‘>"+defaults.menuItem[Item].menuTitle+"</p>"+"<ul class=‘submenu‘>";
		    		for( SubItem = 0;SubItem < submenuLength;SubItem++){
		    			MenuDom +="<li class=‘subMenuItem‘>"+defaults.menuItem[Item].subMenuList[SubItem]+"</li>"
		    		}
		    		MenuDom +="<ul></li>"
		        }else{
		        	MenuDom +="<li class=‘menuItem‘><p class=‘menuTitle‘>"+defaults.menuItem[Item].menuTitle+"</p></li>"
		        }

		    }

	    /******添加动作**********/
	    	MenuDom = $(MenuDom);
		  	MenuDom.find(".submenu").hide();
		    MenuDom.find(".menuTitle").bind("click",function(){
		     	$(this).siblings(".submenu").toggle();

		     });
		/***添加样式****/
		if(defaults.MenuCss.MTitleCss)
			MenuDom.find(".menuTitle").css(defaults.MenuCss.MTitleCss);
		if(defaults.MenuCss.SubMenuCss)
			MenuDom.find(".submenu").css(defaults.MenuCss.SubMenuCss);

		  /***/
		    $(this).append(MenuDom).wrapInner("<ul></ul>");
		    /*****生成菜单节点*******/	

		  return this;

	}

})(jQuery);

效果截图如下:

总结:

  UI插件写法,

   1.首先要考虑有哪些参数是要传入的,通常在插件内定义defaults JSON对象设参数的默认值,然后使用$.extend()方法合并参数与默认参数,

    一般UI需要传递的参数有css样式json对象,回调函数等,具体可查看extjs的控件参数

   2.需要根据生产DOM节点也即随机生产相应的HTML结构(包括设置class,id),

   3.为节点绑定css样式,根据参数的需要判断是否添加,(尽量在外部css文件设置样式)

   4.为节点绑定事件动作

//css.文件可为UI样式设置默认样式

时间: 2024-10-27 06:44:15

jquery插件开发尝试(二)的相关文章

jquery插件开发示例(二)

(function(window, $, undefined) { $.fn.sidebar = function(options) { var defaults = { menuoverevent: 'mouseover', menuleaveevent: 'mouseleave', foldevent: 'click', menuThumbnailSelector: ".menu-thumbnail", menumeta: ['flow', 'account', 'common',

jQuery插件开发 总结

一般来说,jQuery插件的开发分为两种:一种是挂在jQuery命名空间下的全局函数,也可称为静态方法:另一种是jQuery对象级别的方法,即挂在jQuery原型下的方法,这样通过选择器获取的jQuery对象实例也能共享该方法. 一.在讲解jQuery插件基本结构和模式前,先介绍下两个重要的方法: 1.$.extend(target, [object1], [objectN]) 该方法主要用于合并两个或更多对象的内容(属性)到第一个对象,并返回合并后的第一对象.如果该方法只有一个参数target

jQuery插件开发的模式和结构

jQuery插件开发 一般来说,jQuery插件的开发分为两种:一种是挂在jQuery命名空间下的全局函数,也可称为静态方法:另一种是jQuery对象级别的方法,即挂在jQuery原型下的方法,这样通过选择器获取的jQuery对象实例也能共享该方法. 一.在讲解jQuery插件基本结构和模式前,先介绍下两个重要的方法,还有不知啥原因,代码无法折叠,导致整体篇幅稍微有点长,阅读时请加点耐心: 1.$.extend(target, [object1], [objectN]) 该方法主要用于合并两个或

jQuery插件开发(一):jQuery类方法

一.jQuery插件开发的方法 jQuery插件的编写方法主要有两种: 1.基于jQuery对象的插件 2.基于jQuery类的插件 二.基于jQuery类的插件 1.什么是jQuery类的插件? jQuery类方法其实就是jquery全局函数,即jquery对象的方法,实际上就是位于jquery命名空间的内部函数.这些函数有一个特征就是不操作DOM元素,而是操作 Javascript非元素对象.直观的理解就是给jquery类添加类方法,可以理解为添加静态方法 2.给jQuery类添加方法. /

jQuery插件开发精品教程(让你的jQuery更上一个台阶)

刘哇勇的部落格要说jQuery 最成功的地方,我认为是它的可扩展性吸引了众多开发者为其开发插件,从而建立起了一个生态系统.这好比大公司们争相做平台一样,得平台者得天下.苹果,微软,谷歌等巨头,都有各自的平台及生态圈. 学会使用jQuery并不难,因为它简单易学,并且相信你接触jQuery后肯定也使用或熟悉了不少其插件.如果要将能力上升一个台阶,编写一个属于自己的插件是个不错的选择. 本教程可能不是最精品的,但一定是最细致的. jQuery插件开发模式 软件开发过程中是需要一定的设计模式来指导开发

JQuery插件开发精品教程,让你的jQuery提升一个台阶

本文转载自 http://www.cnblogs.com/Wayou/p/jquery_plugin_tutorial.html 要说jQuery 最成功的地方,我认为是它的可扩展性吸引了众多开发者为其开发插件,从而建立起了一个生态系统.这好比大公司们争相做平台一样,得平台者得天下.苹果,微软,谷歌等巨头,都有各自的平台及生态圈. 学会使用jQuery并不难,因为它简单易学,并且相信你接触jQuery后肯定也使用或熟悉了不少其插件.如果要将能力上升一个台阶,编写一个属于自己的插件是个不错的选择.

jQuery插件开发模式

http://www.cnblogs.com/gavin-num1/p/5655126.html jQuery插件开发模式 软件开发过程中是需要一定的设计模式来指导开发的,有了模式,我们就能更好地组织我们的代码,并且从这些前人总结出来的模式中学到很多好的实践. 根据<jQuery高级编程>的描述,jQuery插件开发方式主要有三种: 通过$.extend()来扩展jQuery 通过$.fn 向jQuery添加新的方法 通过$.widget()应用jQuery UI的部件工厂方式创建 通常我们使

jQuery插件开发---转载

要说jQuery 最成功的地方,我认为是它的可扩展性吸引了众多开发者为其开发插件,从而建立起了一个生态系统.这好比大公司们争相做平台一样,得平台者得天下.苹果,微软,谷歌等巨头,都有各自的平台及生态圈. 学会使用jQuery并不难,因为它简单易学,并且相信你接触jQuery后肯定也使用或熟悉了不少其插件.如果要将能力上升一个台阶,编写一个属于自己的插件是个不错的选择. 本教程可能不是最精品的,但一定是最细致的. jQuery插件开发模式 软件开发过程中是需要一定的设计模式来指导开发的,有了模式,

跟我一起学JQuery插件开发

http://www.cnblogs.com/Leo_wl/archive/2012/04/06/2435511.html 以前一直比较好奇,jquery插件是怎么开发的,怎么写属于自己的插件? 昨天在逛codeproject网站的时候,突然看到一篇文章:How to write plugin in Jquery. 如果对E文好的同学 ,可以看上面的连接. 现在我把上面网站的及结合自己的想法写这篇文章.希望能得到大牛们的支持和谅解...大鸟飞过...欢迎拍装. 资料来源: [1]How to w