热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

让你基于jQuery的插件兼容commonjs,amd范例

事变是如许的,我写了一个基于jQuery的插件,在传统的开辟形式中,我们须要如今页面引入jQuery.js,然后在引入我们的插件,我们的插件才运用。然则跟着webpack的鼓起,我

事变是如许的,我写了一个基于jQuery的插件,在传统的开辟形式中,我们须要如今页面引入jQuery.js,然后在引入我们的插件,我们的插件才运用。然则跟着webpack的鼓起,我不在想一步步的写入script标签,写着一堆的script标签。然则我们晓得这些都有着模块范例。比如在node环境中我们常常如许写:var example = require(‘./example.js’);那末就让我们的插件也支撑如许的写法吧。

先看传统式jQuery插件的写法。(jquery的插件有许多种写法,这里就不过量议论)

;(function($,window){
var plugin=function(){
}
plugin.prototype={
a:function(){
},
b:function(){
}
}
window.plugin=plugin;
})($,window)

如许我们在页面中如许写:

var p = new plugin()

题目来了,我都是用webpack来打包js文件的,怎样能够经由过程require(’./plugin.js’)的体式格局来引入我的插件呢?

node的模块范例是commonjs,这些我们是晓得的,网上也有很引见,鄙人就不多哔哔了。然则题目来了,网上许多只是引见怎样把一个模块导出,然则当你的模块依靠某个模块时,这时候该怎样处置惩罚?

先看一段代码

(function(window,$){
var mtable = function (opt, data) {
this.tableId = opt.tableid;
this.tableClass = opt.tableclass;
this.tableParent = opt.tableparent;
......
this.mergeCells = opt.mergeCells || false;
if (this instanceof mtable) {
this.init();
return this;
} else {
return new mtable(opt, data).init()
}
} mtable.prototype = {
constructor: mtable,
init: function () {
var that = this;
that.createTable();
//兼并单元格
if (this.mergeCells == true) {
mtable.MergeCell(that.tableId)
}
this.addEventDom();
this.removeEventDom();
},
addEventDom: function () {
var that = this;
//在这里我们运用了jquery
$(this.addDom).on('click', function () {
console.log("最先临盆表格...")
that.createTable();
})
}
}
})(window,$)

接着我们尝试着在闭包函数中,写写兼容模块,让函数能被导出去

//兼容模块
if(typeof module !=='undefined' && typeof exports ==='object'){
module.exports=mtable;
}else if(typeof define ==='function' && (define.amd || define.cmd)){
define(function(){
return mtable;
})
}else{
window.mtable=mtable;
}

然则我们经由过程 var mtable = require('mtable')时,经由webpack打包,会发明览器毛病提醒$ is not defined
既然$ is not defined 申明我们并没把jQuery这个参数传进去。

在换种体式格局call()函数,对,你没看错,这个要领常常被人拿出来引见。。。

//如果是在node环境中,经由过程require引入jQuery中,如果是在浏览器中,就经由过程window体式格局通报jQuery
if(typeof module !=='undefined' && typeof exports ==='object'){
var $=require('jquery');
}else{
var $=window.$
}
(function(){
var mtable = function (opt, data) {
this.tableId = opt.tableid;
this.tableClass = opt.tableclass;
this.tableParent = opt.tableparent;
this.table;
this.theade = opt.theade;
this.addDom = opt.adddom;
this.removeDom = opt.removedom;
this.data = data;
this.mergeCells = opt.mergeCells || false;
if (this instanceof mtable) {
this.init();
return this;
} else {
return new mtable(opt, data).init()
}
}
mtable.prototype = {
constructor: mtable,
init: function () {
var that = this;
that.createTable();
//兼并单元格
if (this.mergeCells == true) {
mtable.MergeCell(that.tableId)
}
this.addEventDom();
this.removeEventDom();
return this;
},
createTable: function () {
var that = this;
var t = createTable({
id: that.tableId,
class: that.tableClass
}, that.data, that.theade);
if (this.tableParent != null && this.tableParent != '') {
$(this.tableParent).append(t)
} else {
document.body.appendChild(t);
}
},
addEventDom: function () {
var that = this;
//var tableObj=document.getElementById('m');
$(this.addDom).on('click', function () {
console.log("最先临盆表格...")
that.createTable();
})
},
removeEventDom: function () {
$(this.removeDom).on('click', function () {
})
}
}
$.each(data, function (index, item) {
var tr = document.createElement("tr");
for (var i in item) {
console.log(item)
var td = document.createElement("td");
td.innerHTML = item[i];
tr.appendChild(td);
}
tbody.appendChild(tr);
});
vtable.appendChild(tbody);
return vtable;
}
}
//兼容模块
if(typeof module !=='undefined' && typeof exports ==='object'){
module.exports=mtable;
}else if(typeof define ==='function' && (define.amd || define.cmd)){
define(function(){
return mtable;
})
}else{
window.mtable=mtable;
}
}).call(function(){
return (typeof window !=='undefined' ? window : global )
},$)//传入$

不论是在node中,照样在浏览器中都能够引用了。

示例


var mtable=require("../lib/easyTable");
var data = [
{ 'a': '小明', 'b': '100' },
{ 'a': '小明', 'b': '250' },
{ 'a': '小明', 'b': '260' },
{ 'a': '小明', 'b': '270' },
{ 'a': '小花', 'b': '90' },
{ 'a': '小花', 'b': '190' }
]
var c = new mtable({
tableid: 'm',
adddom: ".add",
tableclass: 'table table-bordered',
tableparent: '.tcon',
theade: '姓名价钱',
mergeCells: true
}, data)

基于上面的要领我写了个浅易的基于jQuery的自动天生表格的插件,能够兼并单元格。关于兼容commonjs这些范例,写法也许多,愿望多多指教
完全代码github:easyTable


推荐阅读
  • 深入理解Vue.js:从入门到精通
    本文详细介绍了Vue.js的基础知识、安装方法、核心概念及实战案例,帮助开发者全面掌握这一流行的前端框架。 ... [详细]
  • 毕业设计:基于机器学习与深度学习的垃圾邮件(短信)分类算法实现
    本文详细介绍了如何使用机器学习和深度学习技术对垃圾邮件和短信进行分类。内容涵盖从数据集介绍、预处理、特征提取到模型训练与评估的完整流程,并提供了具体的代码示例和实验结果。 ... [详细]
  • 本文介绍了多个关于JavaScript的书籍资源、实用工具和编程实例,涵盖从入门到进阶的各个阶段,帮助读者全面提升JavaScript编程能力。 ... [详细]
  • 解读MySQL查询执行计划的详细指南
    本文旨在帮助开发者和数据库管理员深入了解如何解读MySQL查询执行计划。通过详细的解析,您将掌握优化查询性能的关键技巧,了解各种访问类型和额外信息的含义。 ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • 本文讨论了如何根据特定条件动态显示或隐藏文件上传控件中的默认文本(如“未选择文件”)。通过结合CSS和JavaScript,可以实现更灵活的用户界面。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • 本教程涵盖OpenGL基础操作及直线光栅化技术,包括点的绘制、简单图形绘制、直线绘制以及DDA和中点画线算法。通过逐步实践,帮助读者掌握OpenGL的基本使用方法。 ... [详细]
  • 汇编语言等号伪指令解析:探究其陡峭的学习曲线
    汇编语言以其独特的特性和复杂的语法结构,一直被认为是编程领域中学习难度较高的语言之一。本文将探讨汇编语言中的等号伪指令及其对初学者带来的挑战,并结合社区反馈分析其学习曲线。 ... [详细]
  • 在网站制作中随时可用的10个 HTML5 代码片段
    HTML很容易写,但创建网页时,您经常需要重复做同样的任务,如创建表单。在这篇文章中,我收集了10个超有用的HTML代码片段,有HTML5启动模板、空白图片、打电话和发短信、自动完 ... [详细]
  • 使用JS、HTML5和C3创建自定义弹出窗口
    本文介绍如何结合JavaScript、HTML5和C3.js来实现一个功能丰富的自定义弹出窗口。通过具体的代码示例,详细讲解了实现过程中的关键步骤和技术要点。 ... [详细]
  • libsodium 1.0.15 发布:引入重大不兼容更新
    最新发布的 libsodium 1.0.15 版本带来了若干不兼容的变更,其中包括默认密码散列算法的更改和其他重要调整。 ... [详细]
  • 最近团队在部署DLP,作为一个技术人员对于黑盒看不到的地方还是充满了好奇心。多次咨询乙方人员DLP的算法原理是什么,他们都以商业秘密为由避而不谈,不得已只能自己查资料学习,于是有了下面的浅见。身为甲方,虽然不需要开发DLP产品,但是也有必要弄明白DLP基本的原理。俗话说工欲善其事必先利其器,只有在懂这个工具的原理之后才能更加灵活地使用这个工具,即使出现意外情况也能快速排错,越接近底层,越接近真相。根据DLP的实际用途,本文将DLP检测分为2部分,泄露关键字检测和近似重复文档检测。 ... [详细]
  • 本题探讨如何通过最大流算法解决农场排水系统的设计问题。题目要求计算从水源点到汇合点的最大水流速率,使用经典的EK(Edmonds-Karp)和Dinic算法进行求解。 ... [详细]
  • 本文详细介绍了Linux系统中init进程的作用及其启动过程,解释了运行级别的概念,并提供了调整服务启动顺序的具体步骤和实例。通过了解这些内容,用户可以更好地管理系统的启动流程和服务配置。 ... [详细]
author-avatar
手机用户2502873943
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有