一,开篇分析
Hi,大家好!前两篇文章我们主要讲述了以“jQuery的方式如何开发插件”,以及过程化设计与面向对象思想设计相结合的方式是如何设计一个插件的,两种方式各有利弊取长补短,嘿嘿嘿,废话少说,进入正题。直接上实际效果图:
大家看到了吧,这是一个下拉菜单插件,在我们日常开发中,系统提供的可能有时让我们觉得不是很美观并且功能有限,造成用户
的体验形式以及用户的可交互性不是很好,所以今天模拟一个嘿嘿嘿。下面就具体分析一下吧。
(二),实例分析
(1),首先确定这个插件做什么事。下面看一下插件的调用方式,以及配置参数说明。如下代码:
$(function(){ var itemSelector = new ItemSelector($("#item-selector"),{ currentText : "Please Choose Item" , items : [ { text : "JavaScript" , value : "js" , disabled : "1" } , { text : "Css" , value : "css" , disabled : "0" } , { text : "Html" , value : "html" , disabled : "0" } ] , mode : "0" , // 为"1"时支持checkbox多选模式 change : function(value){ // put your code here } }) ; itemSelector.init() ; setTimeout(function(){ console.log(itemSelector.getCurrentValue()) ; // 测试 获取当先选中项 },2000) ;
“var itemSelector = new ItemSelector()”里面包含两个参数,第一个是dom节点对象,第二个是插件参数选项,"currentText"代表“ItemSelector“插件中,选中文本显示区域的文字描述。
”items“是一个数组,里面包含的是“ItemSelector”项目的属性,包括文字描述,选项值,”disabled“代表列表条目的可显度,0代表显示,1代表不可显示。
”change“代表选中时的操作回调函数,选项数据会以参数的形式进行回传。
(2),所涉的功能有哪些
可显的效果图如下:
不可显的效果图如下:
二者的区别是:不可现状态数据不会回传,悬浮上去不会有任何效果。
三),完整代码以供学习,本代码已经过测试,包括目录结构以及相关的文件。
(1),html
<body> <div class="dxj-ui-hd"> 大熊君{{bb}} - DXJ UI ------ ItemSelector </div> <div class="dxj-ui-bd"> <div id="item-selector"> <div class="title"> <div></div><span>↓</span> </div> <div class="content"> <div class="items"> </div> </div> </div> </div> </body>
(2),css
/* item-selector */ #item-selector { margin : 0 auto; width : 220px ; overflow:hidden; border:2px solid #ccc; } #item-selector .title { border-bottom:1px solid #ccc; overflow:hidden; } #item-selector .title div { width:190px; border:0px ; color:#999; font-family: arial ; font-size: 14px; height:28px; line-height:28px; float:left; cursor:pointer; } #item-selector .title span { display:block; height:30px; line-height:30px; width:29px; float:left; text-align:center; border-left:1px solid #ccc; cursor:pointer; } #item-selector .content { width : 220px ; overflow:hidden; } #item-selector .content .items { overflow:hidden; } #item-selector .content .items div { padding-left:20px; width : 200px ; height:32px; line-height:32px; font-family: "微软雅黑" ; font-size: 14px; font-weight:bold; cursor:pointer; } .item-hover { background:#3385ff; color:#fff; }
(3),"ItemSelector.js"
function ItemSelector(elem,opts){ this.elem = elem ; this.opts = opts ; } ; var ISProto = ItemSelector.prototype ; ISProto.getElem = function(){ return this.elem ; } ; ISProto.getOpts = function(){ return this.opts ; } ; /* data manip*/ ISProto._setCurrent = function(current){ this.getOpts()["current"] = current ; } ; ISProto.getCurrentValue = function(current){ return this.getOpts()["current"] ; } ; /* data manip*/ ISProto.init = function(){ var that = this ; this.getOpts()["current"] = null ; // 数据游标 this._setItemValue(this.getOpts()["currentText"]) ; var itemsElem = that.getElem().find(".content .items") ; this.getElem().find(".title div").on("click",function(){ itemsElem.toggle() ; }) ; this.getElem().find(".title span").on("click",function(){ itemsElem.toggle() ; }) ; $.each(this.getOpts()["items"],function(i,item){ item["id"] = (new Date().getTime()).toString() ; that._render(item) ; }) ; } ; ISProto._setItemValue = function(value){ this.getElem().find(".title div").text(value) } ; ISProto._render = function(item){ var that = this ; var itemElem = $("<div></div>") .text(item["text"]) .attr("id",item["id"]) ; if("0" == item["disabled"]){ itemElem.on("click",function(){ var onChange = that.getOpts()["change"] ; that.getElem().find(".content .items").hide() ; that._setItemValue(item["text"]) ; that._setCurrent(item) ; onChange && onChange(item) ; }) .mouseover(function(){ $(this).addClass("item-hover") ; }) .mouseout(function(){ $(this).removeClass("item-hover") ; }) ; } else{ itemElem.css("color","#ccc").on("click",function(){ that.getElem().find(".content .items").hide() ; that._setItemValue(item["text"]) ; }) ; } itemElem.appendTo(this.getElem().find(".content .items")) ; } ;
(四),最后总结
(1),面向对象的思考方式合理分析功能需求。
(2),以类的方式来组织我们的插件逻辑。
(3),不断重构上面的实例,如何进行合理的重构那?不要设计过度,要游刃有余,推荐的方式是过程化设计与面向对象思想设计相结合。
(4),下篇文章中会扩展相关功能,比如“mode”这个属性,为"1"时支持checkbox多选模式,现在只是默认下拉模式。
本文先到这里了,后续我们再继续讨论,希望小伙伴们能够喜欢本系列文章。
本文向大家介绍JavaScript插件化开发教程(六),包括了JavaScript插件化开发教程(六)的使用技巧和注意事项,需要的朋友参考一下 一,开篇分析 今天这篇文章我们说点什么那?嘿嘿嘿。我们接着上篇文章对不足的地方进行重构,以深入浅出的方式来逐步分析,让大家有一个循序渐进提高的过程。废话少说,进入正题。让我们先来回顾一下之前的 Js部分的代码,如下: 效果如下图所示: a)----
这是一本讲述kibana插件开发教程类的书籍,写这本书的时候,还没有深入开发过kibana插件,书中难免会出现各种错误,欢迎大家指正交流。
本文向大家介绍jQuery插件开发详细教程,包括了jQuery插件开发详细教程的使用技巧和注意事项,需要的朋友参考一下 扩展jQuery插件和方法的作用是非常强大的,它可以节省大量开发时间。这篇文章将概述jQuery插件开发的基本知识,最佳做法和常见的陷阱。 一、入门 编写一个jQuery插件开始于给jQuery.fn加入新的功能属性,此处添加的对象属性的名称就是你插件的名称: 用户非常喜欢的
重要说明 IntelliJ IDEA 的插件理论上是同时也适用于 JetBrains 公司下的其他大多数 IDE 的,因为这些 IDE 都是基于 IntelliJ IDEA 的基础平台进行开发的,请牢记这一点。 教程视频下载和介绍 视频章节结构: 01_AS插件是什么_和IntellijIDEA关系 02_常见的AS开发插件 03_创建第一个Plugin插件 04_翻译插件需求 05_翻译开发过程
确定功能,先给插件起名,英文名和中文名 如:Demo,插件演示,然后在public/plugins目录里添加这个插件目录(demo) 确定是否要后台配置文件,如果需要在插件根目录加上config.php,格式可看文档“插件配置文件” 创建插件主类文件,查看“插件类主文件” 确定是否要模板,如需要请根目录添加view目录 确定是否可以外部访问,如需要请加controller目录,再添加Control
确定功能,先给插件起名,英文名和中文名 如:Demo,插件演示,然后在plugins目录里添加这个插件目录 确定是否要后台配置文件,如果需要在插件根目录加上config.php,格式可看文档“插件配置文件” 创建插件主类文件,查看“插件类主文件” 确定是否要模板,如需要请根目录添加View目录 确定是否可以外部访问,如需要请加Controller目录,再添加Controller文件 给自己的模板(