jQuery自定义类封装

----- 写法1 -------

var uploadProcess = (function ($) {
    var pub = {
        delete: function (element) {
            var params = {upload_id:$(element).data('id')};
            var urlDelete = '<?= Url::to('delete-upload')?>';
            $.post(
                urlDelete,
                params,
                function (data) {
                    if(data.result>0){
                        $(element).closest('div.att-item').remove();
                    }
                    //console.log(data);
                }, 'json');
                
            return false;
        }
    }
    return pub;    
})(window.jQuery);


>>方法1调用demo

$('.upload-attachment-list').on('click', 'a.delete-item', function(){
        if(confirm('Confirm delete?')){uploadProcess.delete(this)}      
    });



----- 写法2 -------

(function (factory) {
  if (typeof define === 'function' && define.amd) {
    // AMD. Register as anonymous module.
    define(['jquery'], factory);
  } else if (typeof exports === 'object') {
    // Node / CommonJS
    factory(require('jquery'));
  } else {
    // Browser globals.
    factory(jQuery);
  }
})(function ($) {

  $.DragField = function (arg) {
        var name = "你好";                 //私有变量,外部无法访问
        this.testFun = function () {     //this.testFun方法,加上了this,就是公有方法了,外部可以访问。
            alert(arg.title + "," + name);
        };
    };


});


----- 写法3 -------

(function ($) {

    $.DragField = function (arg) {

        var name ="你好";

        this.testFun =function () {

            alert(arg.title + "," + name);

        };

    };

})(jQuery);

 

方法2,方法3 使用方法:

var a =new $.DragField({ title:"Hi" });

var b =new $.DragField({ title:"Hello" });

a.testFun();

b.testFun();



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值