当前位置: 58彩票app下载 > 计算机网络 > 正文

jQueryUI如何自定义组件实现代码

时间:2019-09-18 11:13来源:计算机网络
什么样初叶接纳 先是用$.widget()方法开头定义你的零件,它只接受四个参数:第四个是组件名称,第二个是可选的基类组件(私下认可的基类是$.Widget),第一个是组件的原型。 零件名

什么样初叶接纳 先是用$.widget()方法开头定义你的零件,它只接受四个参数:第四个是组件名称,第二个是可选的基类组件(私下认可的基类是$.Widget),第一个是组件的原型。
零件名称必得包含命名空间,要留心的是,官方组件的命名空间是以‘ui'最初的,例如:‘ui.tabs'。笔者在底下的用‘小编'的拼音(‘wo')。

复制代码 代码如下:

$.widget("yourNamespace.yourWidgetName",[yourBaseWidget],yourWidgetPrototype)

$.Widget基类含有一个尤为重要的品质‘options',它用来定义公有参数,组件伊始化时外界调用的参数会覆盖内部定义的参数;以及多个根本的民用的不二诀窍‘_create'、‘_init'、‘',前七个约等于构造函数的意义,按顺序施行,_create()方法试行之后会触发'create'事件。 _trigger()方法会将参数中的内定函数标准化为W3C事件,而且触发那些自定义事件。
别的还应该有多个国有方法‘enable',‘disable',‘destroy',分别代表启用、禁止使用和销毁组件。
那边很有趣的,是个人方法和国有方法的达成。jQuerUI Widget暴光的主意都以不以‘_'开头的:

复制代码 代码如下:

// prevent calls to internal methods
if ( isMethodCall && options.charAt( 0 ) === "_" ) {
return returnValue;
}

实质上,jQueryUI Widget依旧封存了土生土养的API,比方那样使用:

复制代码 代码如下:

var $div = $('.demo:first');
var api = $div.data('divZoom');
// console.dir(api);
api.zoomIn();
// 对比
$div.divZoom('zoomIn');

三个落实完全私有变量的小技巧:

复制代码 代码如下:

(function($) {
var privateVar = '';
$.widget("wo.divZoom",{});
})(jQuery)

有着代码

复制代码 代码如下:

/*
* @by ambar
* @create 2010-10-20
* @update 2010-10-25
*/
(function($) {
var html = '<div class="icon-zoom">
<span title="zoom in" class="zoom-in">zoom in</span>
<span title="zoom out" class="zoom-out">zoom out</span>
</div>';
$.widget("wo.divZoom",{
_init : function() {
var self = this, opt = self.options, tgt = opt.target, $el = self.element ;
// 早先二遍
if($('div.icon-zoom',$el).length) return;
$el.append(html);
self.target = ( tgt == '' ? $el : $el.find(tgt) );
// 检查测验初步值
var level = self.target.attr(opt.dataPrefix);
self.target.attr(opt.dataPrefix,level || opt.level[0]);
self.btnZoomIn = $el.find('span.zoom-in').click( $.proxy(self.zoomIn,self) );
self.btnZoomOut = $el.find('span.zoom-out').click( $.proxy(self.zoomOut,self) );
},
destroy : function(){
this.element.find('div.icon-zoom').remove();
},
options : {
level : [120,160,200],
target : '',
speed : 'normal',
dataPrefix : 'data-zoom-level',
zooming : null,
select : null,
show : null
},
currentLevel : function(){
var self = this, opt = self.options, lvl = Number(self.target.attr(opt.dataPrefix));
return $.inArray(lvl,opt.level);
},
zoomIn : function() {
this.zoom(this.currentLevel() + 1);
},
zoomOut : function() {
this.zoom(this.currentLevel() - 1);
},
zoom : function(i){
var self = this, opt = self.options,lvls = opt.level,$tgt = self.target;
if( i<=-1 || i>=lvls.length ) return;
var value = lvls[i],
originalValue = lvls[self.currentLevel()],
style = { width:value, height:value };
var data = { target : $tgt, css : style, originalCss : {width:originalValue,height:originalValue} };
var goon = self._trigger('start',null,data);
if(!goon) return;
$tgt.animate(style,
{
duration : opt.speed,
step : function(val) {
var css = { width:val, height:val };
self._trigger('zooming',null,$.extend({},data,{css:css}));
},
complete : function(){
$tgt.attr(opt.dataPrefix,value);
self._trigger('stop',null,data);
}
});
}
});
})(jQuery)

在页面上调用

复制代码 代码如下:

<script src="js/jquery-1.4.4.min.js"></script>
<script src="js/jquery.ui.widget.js"></script>
<!-- 自定义的 -->
<script src="js/jquery.ui.wo.divZoom.js"></script>
<script type="text/javascript">
$(function() {
$('div.demo').divZoom({
target : '>a',
level : [80,120,160,200],
zooming : function(e,ui){
// console.log(e,ui.css);
},
start : function(e,ui){
console.log('开始',this,e.type,ui);
},
stop : function(e,ui) {
console.log('结束',ui.css);
}
});
});
</script>

示范代码:

复制代码 代码如下:

<!DOCTYPE HTML>
<html lang="en-US">
<head>
<meta charset="UTF-8">
<title>jQueryUI</title>
<style type="text/css">
#receptacle{width:800px;height:500px;background:#cde;position:relative;}
#receptacle .demo{width:80px;height:80px;position:absolute;}
.demo .cont{width:80px;height:80px;display:block;background:#07a;}
.demo-a{top:30px;left:122px;}
.demo-b{top:100px;left:400px;}
.icon-zoom {
position:absolute; width:63px; height:20px; overflow:hidden;
background:url(//files.jb51.net/file_images/photoshop/201011/icon-zoom.png) no-repeat; cursor:pointer;
}
.icon-zoom span { width:20px; display:block; text-indent:-999em; float:left; }
</style>
<!--<script src="js/jquery.ui.core.js"></script>

<script src="jquery-1.4.4.min.js"></script>
<script src="jquery.ui.widget.js"></script>
<!-- 自定义的 -->
<script src="jquery.ui.wo.divZoom.js"></script>

<script type="text/javascript">
$(function() {
$('div.demo').divZoom({
target : '>a',
level : [80,120,160,200],
zooming : function(e,ui){
// console.log(e,ui.css);
},
start : function(e,ui){
console.log('开始',this,e.type,ui);
},
stop : function(e,ui) {
console.log('结束',ui.css);
}
});
});
</script>
</head>
<body>
<p>
<a href=";
</p>
<div id="receptacle">
<div class="demo demo-a">
<a class="cont" href="#a">a</a>
</div>
<div class="demo demo-b">
<a class="cont" href="#b">b</a>
</div>
</div>
</body>
</html>

你或然感兴趣的小说:

  • Dropzone.js完结公文拖拽上传功用(附源码下载)
  • javascript拖拽上传类库DropzoneJS使用方法
  • jQuery移动端图片上传组件
  • jQuery Chart图表制作零部件Highcharts用法详解
  • 浅析jquery的js图表组件highcharts
  • 传说jquery的图形轮播 tab切换组件
  • Confirmer JQuery确认对话框组件
  • jQuery之排序组件的长远分析
  • 选用jquery组件qrcode生成二维码及选择指南
  • jquery组件WebUploader文件上传用法详解
  • jQuery图片拖动组件Dropzone用法示例

编辑:计算机网络 本文来源:jQueryUI如何自定义组件实现代码

关键词: