编写jQueryUI插件(widget)

2024-05-13 23:58
文章标签 编写 插件 widget jqueryui

本文主要是介绍编写jQueryUI插件(widget),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近在做一个项目的时候,要实现动态渲染弹出框的样式,所以用到widget编写插件。学习一下。

使用Jquery ui 的widget来写插件,比较以实现,因为widget已经实现了一些基本的方法,如_create(),destroy(),其次是踏实单例的。

基本语法:

(function($){

function foo(){}

$.widget("命名空间.插件名",$.继承插件的命名空间.插件名,{/snip/})

})(jQuery);

一般来说工具函数写在widget外面比较合适,但如果你想要这些工具函数被子类继承,则需要写在widget里面。

写在widget里面的,就有public和private之分,规则是:

public方法首字符不是_

private方法首字符是_


当调用方法时,会先判断是否以_开头,如果是则不执行调用。

如果我非要在外面调用private方法,该怎么做?并非一点办法也没有:

var instance = $('<div>');
instance.mywidget('publicFunction'); // work
instance.mywidget('_privateFunction'); // silently fail
instance.data('mywidget')._privateFunction(); // work
$.mynamespace.mywidget.prototype._privateFunction(); // work


Jquery的官方文档中对此写的很清晰。一般来说,jquery ui都是继承自jquery.ui.widget.js这个文件的。这个文件提供了一个工厂方法来创建widget对象。其方法是$.widget(String name, Options prototype).下面简单介绍下这个类提供的方法和属性。在创建widget的时候将重写这些。

destroy():将widget实例从dom对象上移除,在开发widget的时候一般此方法是必须的。就是移除你自己在dom element上添加的样式和行为以及dom结构

options:在这里面保存的是widget的配置信息,在创建widget的时候需要设置一些配置参数。

element:就是widget作用的dom对象。

enable()和disable()这两个方法就是禁用和启用widget的。其实是修改options.disabled。

还有两个私有方法是创建widget的时候要重写的。

_create() 这个方法就是创建widget的方法,在页面调用widget的时候,就会执行此方法,来构建widget。Widget的绝大大多数行为和结构都是在这里创建的。

_init() 这个方法大多数时候不会被重写,这个方法在构建widget的时候在_create后执行。从相关的文档上查询到:

_create()方法在widget构建的时候执行,而_init()方法在构建和重新初始化的时候执行。而destroy方法则是在移除widget的时候被执行。在widget中,所有的私有方法都将加以"_"前缀

_setOption():此方法提供了options的属性的设置,一般情况下如果options里面的参数不需要特殊处理(校验,类型转换,以及设置属性的时候触发某一操作等)的时候不需要对此方法进行重写

事件

如果有自定义的事件,可以采用widget为我们封装好的方法来处理_trigger()这个方法来处理,其调用方法 this._trigger(type, event, data),第一个参数为时间类型,第二个参数为事件event对象,第三个参数为事件要传递的参数。

接下来会写一个简单的jquery ui widget来说明如何开发widget

代码Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-->$(function(){
 
    // _create() 和 _init() 在第一次调用的时候被执行
    $("div").mywidget();
 
    // widget已经实例化到div上了,此时只执行_init()方法
 /** jQuery Mobile Framework : plugin to provide a dialogs Widget. ver2* Copyright (c) JTSage* CC 3.0 Attribution.  May be relicensed without permission/notifcation.* https://github.com/jtsage/jquery-mobile-simpledialog*/(function($, undefined ) {$.widget( "mobile.simpledialog2", $.mobile.widget, {options: {version: '1.0.1-2012022700', // jQueryMobile-YrMoDaySerialmode: 'blank', // or 'button'themeDialog: 'b',themeInput: false,themeButtonDefault: false,themeHeader: 'a',fullScreen: false,fullScreenForce: false,dialogAllow: false,dialogForce: false,headerText: false,headerClose: false,buttonPrompt: false,buttonInput: false,buttonPassword: false,blankContent: false,resizeListener: true,safeNuke: true,forceInput: true,showModal: true,animate: true,transition: 'pop',clickEvent: 'click',zindex: '500',width: '580px',left: false,top: false,callbackOpen: false,callbackOpenArgs: [],callbackClose: false,callbackCloseArgs: []},_eventHandler: function(e,p) {// Handle the triggersvar self = e.data.widget,o = e.data.widget.options;if ( ! e.isPropagationStopped() ) {switch (p.method) {case 'close':self.close();break;case 'html':self.updateBlank(p.source);break;}}},_create: function () {var self = this,o = $.extend(this.options, this.element.jqmData('options')),initDate = new Date(),content = $("<div class='ui-simpledialog-container ui-overlay-shadow ui-corner-all ui-simpledialog-hidden " + ((o.animate === true) ? o.transition : '') + " ui-body-" + o.themeDialog + "'></div>");if ( o.themeButtonDefault === false ) { o.themeButtonDefault = o.themeDialog; }if ( o.themeInput === false ) { o.themeInput = o.themeDialog; }$.mobile.sdCurrentDialog = self;if ( typeof $.mobile.sdLastInput !== 'undefined' ) { delete $.mobile.sdLastInput; }self.internalID = initDate.getTime();self.displayAnchor = $.mobile.activePage.children('.ui-content').first();self.dialogPage = $("<div data-role='dialog' class='ui-simpledialog-dialog' data-theme='" + o.themeDialog + "'><div data-role='header'></div><div data-role='content'></div></div>");self.sdAllContent = self.dialogPage.find('[data-role=content]');content.appendTo(self.sdAllContent);self.sdIntContent = self.sdAllContent.find('.ui-simpledialog-container');self.sdIntContent.css('width', o.width);if ( o.headerText !== false || o.headerClose !== false ) {self.sdHeader = $('<div style="margin-bottom: 0px;background-color:black;" class="ui-header win-title ui-bar-'+o.themeHeader+'"></div>');if ( o.headerClose === true ) {$("<a class='ui-btn-right' rel='close' href='#'>Close</a>").appendTo(self.sdHeader).buttonMarkup({ theme  : o.themeHeader, icon   : 'delete', iconpos: 'notext', corners: true, shadow : true });}$('<h1 class="ui-title">'+((o.headerText !== false)?o.headerText:'')+'</h1>').appendTo(self.sdHeader);self.sdHeader.appendTo(self.sdIntContent);}if ( o.mode === 'blank' ) {if ( o.blankContent === true ) {o.blankContent = self.element.html();}$(o.blankContent).appendTo(self.sdIntContent);} else if ( o.mode === 'button' ) {self._makeButtons().appendTo(self.sdIntContent);}self.sdIntContent.appendTo(self.displayAnchor.parent());self.dialogPage.appendTo( $.mobile.pageContainer ).page().css('minHeight', '0px').css('zIndex', o.zindex);if ( o.animate === true ) { self.dialogPage.addClass(o.transition); }self.screen = $("<div>", {'class':'ui-simpledialog-screen ui-simpledialog-hidden'}).css('z-index', (o.zindex-1)).appendTo(self.displayAnchor.parent()).bind(o.clickEvent, function(event){if ( !o.forceInput ) {self.close();}event.preventDefault();});if ( o.showModal ) { self.screen.addClass('ui-simpledialog-screen-modal'); }$(document).bind('simpledialog.'+self.internalID, {widget:self}, function(e,p) { self._eventHandler(e,p); });},_makeButtons: function () {var self = this,o = self.options,buttonHTML = $('<div></div>'),pickerInput = $("<div class='ui-simpledialog-controls'><input class='ui-simpledialog-input ui-input-text ui-shadow-inset ui-corner-all ui-body-"+o.themeInput+"' type='"+((o.buttonPassword===true)?"password":"text")+"' name='pickin' /></div>"),pickerChoice = $("<div>", { "class":'ui-simpledialog-controls' });if ( o.buttonPrompt !== false ) {self.buttonPromptText = $("<p class='ui-simpledialog-subtitle'>"+o.buttonPrompt+"</p>").appendTo(buttonHTML);}if ( o.buttonInput !== false ) {$.mobile.sdLastInput = "";pickerInput.appendTo(buttonHTML);pickerInput.find('input').bind('change', function () {$.mobile.sdLastInput = pickerInput.find('input').first().val();self.thisInput = pickerInput.find('input').first().val();});}pickerChoice.appendTo(buttonHTML);self.butObj = [];$.each(o.buttons, function(name, props) {props = $.isFunction( props ) ? { click: props } : props;props = $.extend({text   : name,id     : name + self.internalID,theme  : o.themeButtonDefault,icon   : 'check',iconpos: 'left',corners: 'true',shadow : 'true',args   : [],close  : true}, props);self.butObj.push($("<a href='#'>"+name+"</a>").appendTo(pickerChoice).attr('id', props.id).buttonMarkup({theme  : props.theme,icon   : props.icon,iconpos: props.iconpos,corners: props.corners,shadow : props.shadow}).unbind("vclick click").bind(o.clickEvent, function() {if ( o.buttonInput ) { self.sdIntContent.find('input [name=pickin]').trigger('change'); }//var returnValue = props.click.apply(self.element[0], arguments);var returnValue = props.click.apply(self, $.merge(arguments, props.args));if ( returnValue !== false && props.close === true ) {self.close();}}));});return buttonHTML;},_getCoords: function(widget) {var self = widget,docWinWidth   = $.mobile.activePage.width(),docWinHighOff = $(window).scrollTop(),docWinHigh    = $(window).height(),diaWinWidth   = widget.sdIntContent.innerWidth(),diaWinHigh    = widget.sdIntContent.outerHeight(),coords        = {'high'    : $(window).height(),'width'   : $.mobile.activePage.width(),'fullTop' : $(window).scrollTop(),'fullLeft': $(window).scrollLeft(),'winTop'  : docWinHighOff + ((widget.options.top !== false) ? widget.options.top : (( docWinHigh / 2 ) - ( diaWinHigh / 2 ) )),'winLeft' : ((widget.options.left !== false) ? widget.options.left : (( docWinWidth / 2 ) - ( diaWinWidth / 2 ) ))};coords.winTop = 40;//if ( coords.winTop < 55 ) { coords.winTop = 40; }return coords;},_orientChange: function(e) {var self = e.data.widget,o = e.data.widget.options,coords = e.data.widget._getCoords(e.data.widget);e.stopPropagation();if ( self.isDialog === true ) {return true;} else {if ( o.fullScreen === true && ( coords.width < 400 || o.fullScreenForce === true ) ) {self.sdIntContent.css({'border': 'none', 'position': 'absolute', 'top': coords.fullTop, 'left': coords.fullLeft, 'height': coords.high, 'width': coords.width, 'maxWidth': coords.width }).removeClass('ui-simpledialog-hidden');} else {self.sdIntContent.css({'position': 'absolute', 'top': coords.winTop, 'left': coords.winLeft}).removeClass('ui-simpledialog-hidden');}}},repos: function() {var bsEvent = { data: {widget:this}, stopPropagation: function () { return true; }};this._orientChange(bsEvent);},open: function() {var self = this,o = this.options,coords = this._getCoords(this);self.sdAllContent.find('.ui-btn-active').removeClass('ui-btn-active');self.sdIntContent.delegate('[rel=close]', o.clickEvent, function (e) { e.preventDefault(); self.close(); });if ( ( o.dialogAllow === true && coords.width < 400 ) || o.dialogForce ) {self.isDialog = true;if ( o.mode === 'blank' ) { // Custom selects do not play well with dialog mode - so, we turn them off.self.sdIntContent.find('select').each(function () {$(this).jqmData('nativeMenu', true);});}self.displayAnchor.parent().unbind("pagehide.remove");self.sdAllContent.append(self.sdIntContent);self.sdAllContent.trigger('create');if ( o.headerText !== false ) {self.sdHeader.find('h1').appendTo(self.dialogPage.find('[data-role=header]'));self.sdIntContent.find('.ui-header').empty().removeClass();}if ( o.headerClose === true ) {self.dialogPage.find('.ui-header a').bind('click', function () {setTimeout("$.mobile.sdCurrentDialog.destroy();", 500);});} else {self.dialogPage.find('.ui-header a').remove();}self.sdIntContent.removeClass().css({'top': 'auto', 'width': 'auto', 'left': 'auto', 'marginLeft': 'auto', 'marginRight': 'auto', 'zIndex': o.zindex});$.mobile.changePage(self.dialogPage, {'transition': (o.animate === true) ? o.transition : 'none'});} else {self.isDialog = false;self.selects = [];if ( o.fullScreen === false ) {if ( o.showModal === true && o.animate === true ) { self.screen.fadeIn('slow'); }else { self.screen.removeClass('ui-simpledialog-hidden'); }}self.sdIntContent.addClass('ui-overlay-shadow in').css('zIndex', o.zindex).trigger('create');if ( o.fullScreen === true && ( coords.width < 400 || o.fullScreenForce === true ) ) {self.sdIntContent.removeClass('ui-simpledialog-container').css({'border': 'none', 'position': 'absolute', 'top': coords.fullTop, 'left': coords.fullLeft, 'height': coords.high, 'width': coords.width, 'maxWidth': coords.width }).removeClass('ui-simpledialog-hidden');} else {self.sdIntContent.css({'position': 'absolute', 'top': coords.winTop, 'left': coords.winLeft}).removeClass('ui-simpledialog-hidden');}$(document).bind('orientationchange.simpledialog', {widget:self}, function(e) { self._orientChange(e); });if ( o.resizeListener === true ) {$(window).bind('resize.simpledialog', {widget:self}, function (e) { self._orientChange(e); });}}if ( $.isFunction(o.callbackOpen) ) {o.callbackOpen.apply(self, o.callbackOpenArgs);}},close: function() {if($("#chioceDramaScope_" + g_currentPage)){$("#chioceDramaScope_" + g_currentPage).hide();}if(searchTextHidden==1){$("#searchText_searchResult").css("visibility","visible");searchTextHidden = 0;}if(searchTextHidden==2){$("#searchText_searchResult2").css("visibility","visible");searchTextHidden = 0;}var self = this, retty;if ( $.isFunction(self.options.callbackClose) ) {retty = self.options.callbackClose.apply(self, self.options.callbackCloseArgs);if ( retty === false ) { return false; }}if ( self.isDialog ) {$(self.dialogPage).dialog('close');self.sdIntContent.addClass('ui-simpledialog-hidden');self.sdIntContent.appendTo(self.displayAnchor.parent());if ( $.mobile.activePage.jqmData("page").options.domCache != true ) {$.mobile.activePage.bind("pagehide.remove", function () {$(this).remove();});}} else {if ( self.options.showModal === true && self.options.animate === true ) {self.screen.fadeOut('slow');} else {self.screen.addClass('ui-simpledialog-hidden');}self.sdIntContent.addClass('ui-simpledialog-hidden').removeClass('in');$(document).unbind('orientationchange.simpledialog');if ( self.options.resizeListener === true ) { $(window).unbind('resize.simpledialog'); }}$.mobile.activePage.find('.ui-btn-active').removeClass('ui-btn-active');if ( self.isDialog === true || self.options.animate === true ) {			setTimeout("$.mobile.sdCurrentDialog.destroy();", 700);//update 2012-6-17 by wyx wo} else {self.destroy();}},destroy: function() {var self = this,ele = self.element;if ( self.options.mode === 'blank' ) {$.mobile.sdCurrentDialog.sdIntContent.find('select').each(function() {if ( $(this).data('nativeMenu') == false ) {$(this).data('selectmenu').menuPage.remove();$(this).data('selectmenu').screen.remove();$(this).data('selectmenu').listbox.remove();}});}$(self.sdIntContent).remove();$(self.dialogPage).remove();$(self.screen).remove();$(document).unbind('simpledialog.'+self.internalID);delete $.mobile.sdCurrentDialog;$.Widget.prototype.destroy.call(self);if ( self.options.safeNuke === true && $(ele).parents().length === 0 && $(ele).contents().length === 0 ) {ele.remove();}},updateBlank: function (newHTML) {var self = this,o = this.options;self.sdIntContent.empty();if ( o.headerText !== false || o.headerClose !== false ) {self.sdHeader = $('<div style="background-color:black" class="ui-header win-title ui-bar-'+o.themeHeader+'"></div>');if ( o.headerClose === true ) {$("<a class='ui-btn-right' rel='close' href='#'>Close</a>").appendTo(self.sdHeader).buttonMarkup({ theme  : o.themeHeader, icon   : 'delete', iconpos: 'notext', corners: true, shadow : true });}$('<h1 class="ui-title">'+((o.headerText !== false)?o.headerText:'')+'</h1>').appendTo(self.sdHeader);self.sdHeader.appendTo(self.sdIntContent);}$(newHTML).appendTo(self.sdIntContent);self.sdIntContent.trigger('create');$(document).trigger('orientationchange.simpledialog');},_init: function() {this.open();}});
})( jQuery );


    $("div").mywidget();
 
    // 销毁widget
    $("div").mywidget("destroy");
 
    // 因为widget已经被销毁,此时_create()和_init()方法都将被执行
    $("div").mywidget();
 
});

这篇关于编写jQueryUI插件(widget)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/987177

相关文章

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

CnPlugin是PL/SQL Developer工具插件使用教程

《CnPlugin是PL/SQLDeveloper工具插件使用教程》:本文主要介绍CnPlugin是PL/SQLDeveloper工具插件使用教程,具有很好的参考价值,希望对大家有所帮助,如有错... 目录PL/SQL Developer工具插件使用安装拷贝文件配置总结PL/SQL Developer工具插

python编写朋克风格的天气查询程序

《python编写朋克风格的天气查询程序》这篇文章主要为大家详细介绍了一个基于Python的桌面应用程序,使用了tkinter库来创建图形用户界面并通过requests库调用Open-MeteoAPI... 目录工具介绍工具使用说明python脚本内容如何运行脚本工具介绍这个天气查询工具是一个基于 Pyt

MyBatis编写嵌套子查询的动态SQL实践详解

《MyBatis编写嵌套子查询的动态SQL实践详解》在Java生态中,MyBatis作为一款优秀的ORM框架,广泛应用于数据库操作,本文将深入探讨如何在MyBatis中编写嵌套子查询的动态SQL,并结... 目录一、Myhttp://www.chinasem.cnBATis动态SQL的核心优势1. 灵活性与可

maven中的maven-antrun-plugin插件示例详解

《maven中的maven-antrun-plugin插件示例详解》maven-antrun-plugin是Maven生态中一个强大的工具,尤其适合需要复用Ant脚本或实现复杂构建逻辑的场景... 目录1. 核心功能2. 典型使用场景3. 配置示例4. 关键配置项5. 优缺点分析6. 最佳实践7. 常见问题

Mybatis嵌套子查询动态SQL编写实践

《Mybatis嵌套子查询动态SQL编写实践》:本文主要介绍Mybatis嵌套子查询动态SQL编写方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、实体类1、主类2、子类二、Mapper三、XML四、详解总结前言MyBATis的xml文件编写动态SQL

MyBatis分页插件PageHelper深度解析与实践指南

《MyBatis分页插件PageHelper深度解析与实践指南》在数据库操作中,分页查询是最常见的需求之一,传统的分页方式通常有两种内存分页和SQL分页,MyBatis作为优秀的ORM框架,本身并未提... 目录1. 为什么需要分页插件?2. PageHelper简介3. PageHelper集成与配置3.

Maven 插件配置分层架构深度解析

《Maven插件配置分层架构深度解析》:本文主要介绍Maven插件配置分层架构深度解析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Maven 插件配置分层架构深度解析引言:当构建逻辑遇上复杂配置第一章 Maven插件配置的三重境界1.1 插件配置的拓扑

Idea插件MybatisX失效的问题解决

《Idea插件MybatisX失效的问题解决》:本文主要介绍Idea插件MybatisX失效的问题解决,详细的介绍了4种问题的解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录一、重启idea或者卸载重装MyBATis插件(无需多言)二、检查.XML文件与.Java(该文件后缀Idea可能会隐藏

使用Java编写一个字符脱敏工具类

《使用Java编写一个字符脱敏工具类》这篇文章主要为大家详细介绍了如何使用Java编写一个字符脱敏工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、字符脱敏工具类2、测试工具类3、测试结果1、字符脱敏工具类import lombok.extern.slf4j.Slf4j