最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

jQuery为开发插件提拱了两个方法

来源:动视网 责编:小采 时间:2020-11-27 20:16:50
文档

jQuery为开发插件提拱了两个方法

jQuery为开发插件提拱了两个方法:jQuery为开发插件提拱了两个方法,分别是:jQuery.fn.extend(); jQuery.extend();jQuery.fnjQuery.fn = jQuery.prototype = {init: function( selector, context ) {//….//……};原来 jQuery.fn = jQuery.pr
推荐度:
导读jQuery为开发插件提拱了两个方法:jQuery为开发插件提拱了两个方法,分别是:jQuery.fn.extend(); jQuery.extend();jQuery.fnjQuery.fn = jQuery.prototype = {init: function( selector, context ) {//….//……};原来 jQuery.fn = jQuery.pr


jQuery为开发插件提拱了两个方法,分别是:

jQuery.fn.extend();

jQuery.extend();

jQuery.fn

jQuery.fn = jQuery.prototype = {init: function( selector, context ) {//….//……};

原来 jQuery.fn = jQuery.prototype.对prototype肯定不会陌生啦。
虽然 javascript 没有明确的类的概念,但是用类来理解它,会更方便。
jQuery便是一个封装得非常好的类,比如我们用 语句 $(“#btn1″) 会生成一个 jQuery类的实例。

jQuery.extend(object)

  • 为jQuery类添加类方法,可以理解为添加静态方法。如:

  • jQuery.extend({
    min: function(a, b) { return a < b ? a : b; },
    max: function(a, b) { return a > b ? a : b; }
    });
    jQuery.min(2,3); // 2 
    jQuery.max(4,5); // 5
    Objectj Query.extend( target, object1, [objectN])
  • 用一个或多个其他对象来扩展一个对象,返回被扩展的对象

  • var settings = { validate: false, limit: 5, name: "foo" }; 
    var options = { validate: true, name: "bar" }; 
    jQuery.extend(settings, options); //结果:settings == { validate: true, limit: 5, name: "bar" }
    jQuery.fn.extend(object);

    对jQuery.prototype进得扩展,就是为jQuery类添加“成员函数”。jQuery类的实例可以使用这个“成员函数”。
    比如我们要开发一个插件,做一个特殊的编辑框,当它被点击时,便alert 当前编辑框里的内容。可以这么做:

    $.fn.extend({ 
     alertWhileClick:function() { 
     $(this).click(function(){ 
     alert($(this).val()); 
     }); 
     } 
    }); 
    $("#input1").alertWhileClick(); // 页面上为: 
    $("#input1") //为一个jQuery实例,当它调用成员方法 alertWhileClick后,便实现了扩展,每次被点击时它会先弹出目前编辑里的内容。

    jQuery.extend() 的调用并不会把方法扩展到对象的实例上,引用它的方法也需要通过jQuery类来实现,如jQuery.init(),而 jQuery.fn.extend()的调用把方法扩展到了对象的prototype上,所以实例化一个jQuery对象的时候,它就具有了这些方法,这 是很重要的,在jQuery.js中到处体现这一点

    jQuery.fn.extend = jQuery.prototype.extend

    你可以拓展一个对象到jQuery的 prototype里去,这样的话就是插件机制了。

    (function( $ ){
    $.fn.tooltip = function( options ) {
    };
    //等价于
    var tooltip = {
    function(options){
    }
    };
    $.fn.extend(tooltip) = $.prototype.extend(tooltip) = $.fn.tooltip
    })( jQuery );

    文档

    jQuery为开发插件提拱了两个方法

    jQuery为开发插件提拱了两个方法:jQuery为开发插件提拱了两个方法,分别是:jQuery.fn.extend(); jQuery.extend();jQuery.fnjQuery.fn = jQuery.prototype = {init: function( selector, context ) {//….//……};原来 jQuery.fn = jQuery.pr
    推荐度:
    标签: 方法 插件 方式
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top