jQuery 플러그인 패키징 단계에 대한 자세한 설명

php中世界最好的语言
풀어 주다: 2018-04-23 15:44:11
원래의
4242명이 탐색했습니다.

이번에는 jQuery 플러그인 캡슐화 단계에 대해 자세히 설명하겠습니다. jQuery 플러그인 캡슐화 시 주의사항은 무엇인가요?

jQuery 플러그인 및 메서드 확장은 매우 강력하며 개발 시간을 많이 절약할 수 있습니다. 이 문서에서는 jQuery 플러그인 개발의 기본, 모범 사례 및 일반적인 함정에 대해 간략하게 설명합니다.

1. 시작하기

jQuery 플러그인 작성은 jQuery.fn에 새 함수 속성을 추가하는 것으로 시작됩니다. 여기에 추가된 객체 속성의 이름은 플러그인의 이름입니다:

. 코드는 다음과 같습니다.

jQuery.fn.myPlugin = function(){ 
//你自己的插件代码 
};
로그인 후 복사

유저들이 그토록 사랑했던 기호들은 어디로 사라졌나요? 여전히 존재하지만 다른 JavaScript 라이브러리와의 충돌을 피하기 위해 jQuery를 자체 실행 폐쇄 프로그램에 전달하는 것이 좋습니다. 여기서 jQuery는 기호로 매핑됩니다. 다른 도서관.

코드는 다음과 같습니다.

(function ($) {
$.fn.myPlugin = function () {
//你自己的插件代码
};
})(jQuery);
로그인 후 복사

이 닫힌 프로그램에서는 $ 기호를 제한 없이 사용하여 jQuery 함수를 표현할 수 있습니다.

2. 환경

이제 실제 플러그인 코드 작성을 시작할 수 있습니다. 하지만 그 전에 플러그인이 위치한 환경에 대한 아이디어가 있어야 합니다. 플러그인 범위에서 this 키워드는 플러그인이 실행할 jQuery 객체를 나타냅니다. 콜백을 포함하는 다른 jQuery 함수에서는 this 키워드가 기본 DOM 요소를 나타내기 때문에 여기서 일반적인 오해가 발생하기 쉽습니다. . 이로 인해 개발자는 아래와 같이 실수로 jQuery에서 this 키워드를 불필요하게 래핑하는 경우가 많습니다.

. 코드는 다음과 같습니다.

(function ($) {
$.fn.myPlugin = function () {
//此处没有必要将this包在$号中如$(this),因为this已经是一个jQuery对象。
//$(this)等同于 $($('#element'));
this.fadeIn('normal', function () {
//此处callback函数中this关键字代表一个DOM元素
});
};
})(jQuery);
$('#element').myPlugin();
로그인 후 복사

3. 기본 지식

이제 jQuery 플러그인의 기본 사항을 이해했으니, 어떤 작업을 수행하는 플러그인을 작성해 보겠습니다.

코드는 다음과 같습니다.

(function ($) {
$.fn.maxHeight = function () {
var max = 0;
this.each(function () {
max = Math.max(max, $(this).height());
});
return max;
};
})(jQuery);
var tallest = $('p').maxHeight(); //返回高度最大的p元素的高度
로그인 후 복사

이는 .height()를 사용하여 페이지에서 높이가 가장 높은 p 요소의 높이를 반환하는 간단한 플러그인입니다.

4. 연쇄성 유지

플러그인의 목적은 단순히 수집된 요소를 어떤 방식으로든 수정하고 이를 체인의 다음 메서드에 전달하는 것인 경우가 많습니다. 이것이 jQuery 디자인의 아름다움이자 jQuery가 인기를 끄는 이유 중 하나입니다. 따라서 플러그인의 연결성을 유지하려면 플러그인이 this 키워드를 반환하는지 확인해야 합니다.

코드는 다음과 같습니다.

(function ($) {
$.fn.lockDimensions = function (type) {
return this.each(function () {
var $this = $(this);
if (!type || type == 'width') {
$this.width($this.width());
}
if (!type || type == 'height') {
$this.height($this.height());
}
});
};
})(jQuery);
$('p').lockDimensions('width').CSS('color', 'red');
로그인 후 복사

플러그인은 이 키워드를 반환하므로 jQuery에서 수집한 요소를 .css와 같은 jQuery 메서드로 계속 제어할 수 있도록 연결성을 유지합니다. 따라서 플러그인이 고유 값을 반환하지 않는 경우 해당 범위 내에서 항상 this 키워드를 반환해야 합니다. 또한 플러그인에 전달된 매개변수가 플러그인 범위 내에서 전달될 것이라고 추론할 수 있습니다. 따라서 이전 예에서는 문자열 'width'가 플러그인의 유형 매개변수가 됩니다.

5. 기본값 및 옵션

더 복잡하고 사용자 정의 가능한 옵션을 많이 제공하는 플러그인의 경우 플러그인 호출 시 확장할 수 있는 기본 설정을 갖는 것이 가장 좋습니다($. 연장하다). 따라서 여러 매개변수를 사용하여 플러그인을 호출하는 대신 재정의하려는 설정이 포함된 개체 매개변수를 사용하여 플러그인을 호출할 수 있습니다.

코드는 다음과 같습니다.

(function ($) {
$.fn.tooltip = function (options) {
//创建一些默认值,拓展任何被提供的选项
var settings = $.extend({
'location': 'top',
'background-color': 'blue'
}, options);
return this.each(function () {
// Tooltip插件代码
});
};
})(jQuery);
$('p').tooltip({
'location': 'left'
});
로그인 후 복사

이 예제에서는 툴팁 플러그인을 호출하면 기본 설정의 위치 옵션이 덮어쓰기되고 배경색 옵션이 기본값으로 유지되므로 최종 호출됩니다. 설정 값은 다음과 같습니다.

코드는 다음과 같습니다.

{
'location': 'left',
'background-color': 'blue'
}
로그인 후 복사

이는 개발자가 사용 가능한 모든 옵션을 정의할 필요 없이 고도로 구성 가능한 플러그인을 제공하는 매우 유연한 방법입니다.

6. 네임스페이스

플러그인 이름을 올바르게 지정하는 것은 플러그인 개발에서 매우 중요한 부분입니다. 올바른 네임스페이스를 사용하면 동일한 페이지에 있는 다른 플러그인이나 다른 코드가 플러그인을 덮어쓸 가능성이 매우 낮다는 것을 보장할 수 있습니다. 네임스페이스는 또한 메소드, 이벤트 및 데이터를 더 잘 추적하는 데 도움이 되기 때문에 플러그인 개발자로서의 삶을 더 쉽게 만듭니다.

7. 플러그인 방식

在任何情况下,一个单独的插件不应该在jQuery.fnjQuery.fn对象里有多个命名空间。

. 代码如下:

(function ($) {
$.fn.tooltip = function (options) {
// this
};
$.fn.tooltipShow = function () {
// is
};
$.fn.tooltipHide = function () {
// bad
};
$.fn.tooltipUpdate = function (content) {
// !!!
};
})(jQuery);
로그인 후 복사

这是不被鼓励的,因为它.fn使.fn命名空间混乱。 为了解决这个问题,你应该收集对象文本中的所有插件的方法,通过传递该方法的字符串名称给插件以调用它们。

. 代码如下:

(function ($) {
var methods = {
init: function (options) {
// this
},
show: function () {
// is
},
hide: function () {
// good
},
update: function (content) {
// !!!
}
};
$.fn.tooltip = function (method) {
// 方法调用
if (methods[method]) {
return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
} else if (typeof method === 'object' || !method) {
return methods.init.apply(this, arguments);
} else {
$.error('Method' + method + 'does not exist on jQuery.tooltip');
}
};
})(jQuery);
//调用init方法
$('p').tooltip();
//调用init方法
$('p').tooltip({
foo: 'bar'
});
// 调用hide方法 
$(‘p').tooltip(‘hide');
//调用Update方法 
$(‘p').tooltip(‘update', ‘This is the new tooltip content!');
로그인 후 복사

这种类型的插件架构允许您封装所有的方法在父包中,通过传递该方法的字符串名称和额外的此方法需要的参数来调用它们。 这种方法的封装和架构类型是jQuery插件社区的标准,它被无数的插件在使用,包括jQueryUI中的插件和widgets。

八、事件

一个鲜为人知bind方法的功能即允许绑定事件命名空间。 如果你的插件绑定一个事件,一个很好的做法是赋予此事件命名空间。 通过这种方式,当你在解除绑定的时候不会干扰其他可能已经绑定的同一类型事件。 你可以通过追加命名空间到你需要绑定的的事件通过 ‘.'。

. 代码如下:

(function ($) {
var methods = {
init: function (options) {
return this.each(function () {
$(window).bind('resize.tooltip', methods.reposition);
});
},
destroy: function () {
return this.each(function () {
$(window).unbind('.tooltip');
})
},
reposition: function () {
//...
},
show: function () {
//...
},
hide: function () {
//...
},
update: function (content) {
//...
}
};
$.fn.tooltip = function (method) {
if (methods[method]) {
return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
} else if (typeof method === 'object' || !method) {
return methods.init.apply(this, arguments);
} else {
$.error('Method ' + method + ' does not exist on jQuery.tooltip');
}
};
})(jQuery);
$('#fun').tooltip();
//一段时间之后… … 
$(‘#fun').tooltip(‘destroy');
로그인 후 복사

在这个例子中,当tooltip通过init方法初始化时,它将reposition方法绑定到resize事件并给reposition非那方法赋予命名空间通过追加.tooltip。 稍后, 当开发人员需要销毁tooltip的时候,我们可以同时解除其中reposition方法和resize事件的绑定,通过传递reposition的命名空间给插件。 这使我们能够安全地解除事件的绑定并不会影响到此插件之外的绑定。

九、数据

通常在插件开发的时候,你可能需要记录或者检查你的插件是否已经被初始化给了一个元素。 使用jQuery的data方法是一个很好的基于元素的记录变量的途径。尽管如此,相对于记录大量的不同名字的分离的data, 使用一个单独的对象保存所有变量,并通过一个单独的命名空间读取这个对象不失为一个更好的方法。

. 代码如下:

(function ($) {
var methods = {
init: function (options) {
return this.each(function () {
var $this = $(this),
data = $this.data('tooltip'),
tooltip = $('<p />', {
text: $this.attr('title')
});
// If the plugin hasn't been initialized yet
if (!data) {
/*
Do more setup stuff here
*/
$(this).data('tooltip', {
target: $this,
tooltip: tooltip
});
}
});
},
destroy: function () {
return this.each(function () {
var $this = $(this),
data = $this.data('tooltip');
// Namespacing FTW
$(window).unbind('.tooltip');
data.tooltip.remove();
$this.removeData('tooltip');
})
},
reposition: function () {
// ...
},
show: function () {
// ...
},
hide: function () {
// ...
},
update: function (content) {
// ...
}
};
$.fn.tooltip = function (method) {
if (methods[method]) {
return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
} else if (typeof method === 'object' || !method) {
return methods.init.apply(this, arguments);
} else {
$.error('Method ' + method + ' does not exist on jQuery.tooltip');
}
};
})(jQuery);
로그인 후 복사

将数据通过命名空间封装在一个对象中,可以更容易的从一个集中的位置读取所有插件的属性。

十、总结和最佳做法

编写jQuery插件允许你做出库,将最有用的功能集成到可重用的代码,可以节省开发者的时间,使开发更高效。 开发jQuery插件时,要牢记:

1.始终包裹在一个封闭的插件:

. 代码如下:

(function($) { 
/* plugin goes here */ 
})(jQuery);
로그인 후 복사

2.不要冗余包裹this关键字在插件的功能范围内

3.除非插件返回特定值,否则总是返回this关键字来维持chainability 。

4.传递一个可拓展的默认对象参数而不是大量的参数给插件。

5.不要在一个插件中多次命名不同方法。

3.始终命名空间的方法,事件和数据。

最后加一个自己写的放大镜的插件`

(function($){$.fn.Fdj=function(){
$('#smallImg').on('mouseover', function() {
$('#slider').show();
})
$('#smallImg').on('mouseout', function() {
$('#slider').hide();
})
$('#smallImg').on('mousemove', function(e) {
var x = e.clientX - $('#slider').width() / 2;
var y = e.clientY - $('#slider').height() / 2;
if(x <= 0) {
x = 0
}
if(x > $('#smallImg').width() - $('#slider').width()) {
x = $('#smallImg').width() - $('#slider').width();
}
if(y <= 0) {
y = 0
}
if(y > $('#smallImg').height() - $('#slider').height()) {
y = $('#smallImg').height() - $('#slider').height();
}
$('#slider').css({
'left': x,
'top': y
})
var X=x/$('#smallImg').width()*800 
var Y=y/$('#smallImg').height()*800
$('#img').css({
left:-X,
top:-Y
})
}) 
}
})(jQuery)
로그인 후 복사

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

怎样快速的操作JQuery元素

使用JQuery操作Ajax(附案例)

위 내용은 jQuery 플러그인 패키징 단계에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿