位置: 编程技术 - 正文

jQuery弹簧插件编写基础之“又见弹窗”(弹簧设计软件手机版)

编辑:rootadmin

推荐整理分享jQuery弹簧插件编写基础之“又见弹窗”(弹簧设计软件手机版),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:jquery 弹窗插件,弹簧设计助手,弹簧设计软件,弹簧设计软件有哪些?,弹簧 插画,弹簧程序编辑,jquery 弹窗插件,jquery 弹窗插件,内容如对您有帮助,希望把文章链接给更多的朋友!

本文将通过一个实例来引出jQuery插件开发中的一些细节,首先介绍下jQuery插件开发的一些基础知识。

jQuery的插件开发主要分为两类:

1. 类级别,即在jQuery类本身上扩展方法,类似与 $.ajax,$.get 等。

2. 对象级别,这里所谓的对象是指通过jQuery选择器选中的jQuery对象,在该对象上添加方法。例如:$('div').css(), $('div').show() 等。

在实际开发中,我们通常选用对象级别的方法来开发插件,jQuery强大的选择器及对象操作是我们选择这种方式很大的一个原因。

接下来我们看看两种方式的具体写法是什么:

类级别的插件开发

在这里,对扩展方法的命名需要考究一些,以免与jQuery类中的原有方法重名。即便如此,当我们需要在类上扩展多个方法时仍有可能会出现命名冲突的情况,为此我们可以创建自定义的命名空间:

对象级别的插件开发

原来是原型链啊。。。

接收配置参数

在编写一个插件时,我们可以让使用插件的人能按自己的意愿设置插件的一些属性,这就需要插件有接收参数的功能,同时当使用插件的人不传入参数时,插件内部也有一套自己默认的配置参数。

这里的关键就是 $.extend 方法,它能够将对象进行合并。对于相同的属性,后面的对象会覆盖前面的对象。为什么extend方法第一个参数是一个空对象呢?因为该方法会将后者合并到前者上,为了不让 defaults 被改变所以第一个参数设为空对象。

如果我们允许使用插件的人能够设置默认参数,就需要将其暴露出来:

这样就可以在外部对插件的默认参数进行修改了。

适当的暴露一些方法

改写:

暴露插件中的一部分方法是很牛逼的,它使得别人可以对你的方法进行扩展、覆盖。但是当别人对你的参数或方法进行修改时,很可能会影响其他很多东西。所以在考虑要不要暴露方法时候要头脑清楚,不确定的就不要暴露了。

保持函数的私有性

说到保持私有性,首先想到什么?没错,就是闭包:

这是jQuery官方给出的插件开发方式,好处包括:1.没有全局依赖 2.避免其他人破坏 3.兼容 '$' 与 'jQuery' 操作符。

如上,debug 方法就成了插件内部的私有方法,外部无法对其进行修改。在闭包前面加 ; 是防止进行代码合并时,如果闭包前的代码缺少分号从而导致后面报错的情况。

合并

以上的代码就创建了一个完整且规范的插件骨架,看起来虽然很简单但在实际开发中还是有很多技巧与注意事项,接下来我们通过一个实例来看看。

想了半天,觉得将弹窗做成插件当作示例是比较合适的。在开发之前我们先构想一下这个弹窗插件的结构与功能等:

从上图我们看出包括三个部分,标题、内容、以及按钮组。这里需要申明一点,我们不想只做成浏览器里默认的只包含一个按钮的alert框,而是使用者可以自定义按钮数量,这样该弹出框也能完成类似confirm框的功能。

搭建插件骨架

1. 我们创建了基于对象且名为 popWin 方法,并将 defaults 默认配置参数暴露出去以便使用的人进行修改;

2. 这里使用面向对象的方法来管理我们的私有函数,createPopWin 方法就是我们私有的用来创建弹窗的函数。

3. 在插件被调用时将jq对象与自定义的参数传入构造函数中并实例化。

调用

jQuery弹簧插件编写基础之“又见弹窗”(弹簧设计软件手机版)

设想一下我们该怎么调用这个插件呢?我们可以在自己的文档树中合适的位置插入一个 div 元素,选中该 div 并调用我们定义在jQuery对象上的 popWin 方法。

调用 popWin 的同时传入自定义的配置参数,之后被选中的 div 元素就被神奇的转化成一个弹窗了!当然,这只是我们的设想,下面开始码代码。

确定默认配置

我们定义了如上的参数,为什么有要传入这么多的CSS类名呢?1. 为了保证JS与CSS尽可能的解耦。 2. 你的样式有很大可能别人并不适用。所以你需要配置一份样式表文件来对应你的默认类名,当别人需要更改样式时可以传入自己编写的样式。

按钮组为一个数组,我们的弹窗需要根据其传入的数组长度来动态的生成若干个按钮。回调函数的作用是在用户点击了某个按钮时返回他所点击按钮的索引值,方便他进行后续的操作。

弹窗DOM创建

1. 首先命名了四个变量用来缓存我们将要创建的四个DOM,将传入的jQuery对象变形成覆盖整个窗口半透明元素;

2. 创建窗口DOM,根据传入的高、宽来设置尺寸并居中,之后另上传入的窗口CSS类名;

3. 创建标题、描述、按钮组区域,并将传入的标题、描述内容配置上去;

4. 动态加入按钮,并为按钮加上data-index的索引值。注册点击事件,点击后调用传入的回调函数,将索引值传回。

好了,我们先看下效果。调用如下:

可以看到一个弹窗的DOM已被渲染到页面中了,当点击关闭按钮时控制台会打印出 "0",因为按钮组只有一个值嘛,当然是第0个了。

如果我们需要多次调用这个弹窗,每次都要传入高、宽我会觉得很麻烦。这时我们可以直接在一开始修改插件内部的默认配置,这也是我们将默认配置暴露的好处:

要注意的当然是不能直接改变defaults的引用,以免露掉必须的参数。 这样以后的调用都无需传入尺寸了。

我们加一个按钮并且传入一个自定义的样式看看好使不呢?

可以看到都是生效了的,当点击“确定”按钮时回调函数返回 0,点击“取消”按钮时回调函数返回 1。这样使用插件的人就知道自己点击的是哪一个按钮,以完成接下来的操作。

显示&隐藏

接下来要进行打开、关闭弹窗功能的开发。回想上面介绍的概念,我们想让使用该插件的人能够对这两个方法进行扩展或者重写,所以将这两个方法暴露出去:

之后在createPopWin方法中需要的地方调用这两个方法。

这里多强调一点,也是做弹窗控件不可避免的一点:只有当我们点击按钮以及灰色背景区域时允许弹窗关闭,点击弹窗其他地方不允许关闭。由于弹窗属于整个灰色区域的子节点,必然牵扯到的就是事件冒泡的问题。

所以在给最外层加上点击关闭的事件时,要在弹窗区域阻止事件冒泡。

二次打开

我们只需要在第一次调用插件时创建所有创建DOM,第二次调用时只更改其参数即可,所以在createPopWin方法最前面加入如下方法:

合并整个插件代码

如上,一个完整的弹窗插件就在这里了。

说下这个标红的 return this 是干什么用的,前面已说过 this 在这里是被选中的jQuery对象。将其return就可以在调用完我们的插件方法后可以继续调用jQ对象上的其他方法,也就是jQuery的链式操作,说玄乎点就叫级联函数。

OK!趁热打铁,我们来看看暴露出去的两个方法重写之后效果怎么样,毕竟对插件暴露部分的扩展和重写是很牛逼的一块东西。

想象个情景,你用了这个插件后觉得简单的show和hide效果简直是low爆了,决定重写这个弹出和隐藏的效果:

你在自己的代码里加上上面两段,然后发现弹窗有了一个简单的上下滑动进入屏幕的效果,同时又不会影响我们弹窗的创建,证明我们的暴露方法还算合理。

当然你也可以让它竖着进、横着进、翻着跟头进,这就看你自己了。

最后贴上默认的样式表,为了急着想粘回去试试的同学们。

当然这只是个编写插件的例子,如果要拿出去使用还需要仔细打磨。例子虽然简单,旨在抛砖引玉。

jQuery使用$.ajax进行即时验证实例详解 本文实例讲述了jQuery使用$.ajax进行即时验证的方法。分享给大家供大家参考,具体如下:这里实现使用jQuery和一般处理程序即时验证用户录入的学号是

jQuery使用$.ajax提交表单完整实例 本文实例讲述了jQuery使用$.ajax提交表单的方法。分享给大家供大家参考,具体如下:首先,新建Login.html页面:!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"

jQuery入门之层次选择器实例简析 本文实例分析了jQuery入门之层次选择器的使用方法。分享给大家供大家参考,具体如下:这里简单介绍一下jQuery层次选择器中ancestordescendant与parentchild的

标签: 弹簧设计软件手机版

本文链接地址:https://www.jiuchutong.com/biancheng/377696.html 转载请保留说明!

上一篇:jQuery点击改变class并toggle及toggleClass()方法定义用法(jquery点击切换背景颜色)

下一篇:jQuery使用$.ajax进行即时验证实例详解

  • 长期股权投资中应采用成本法核算的是
  • 红冲去年暂估的费用怎么做账
  • 应收往来会计是做什么工作的
  • 个人销售货物缴增值税吗
  • 事业单位结余如何分配
  • 递延资产放在资产负债表哪里
  • 跨年暂估收入如何调整
  • 公司车辆交强险需要什么手续
  • 对于税收会计记账科目应该如何设置?
  • 开出增值税发票没收到怎么抵扣进项税?
  • 污泥处置费用怎么开票
  • 辞退福利应该计入什么科目
  • 电脑变成代码打不开怎么办
  • 预缴增值税被挂账怎么办
  • 什么情况下要办居住证
  • 跨年补交企业所得税
  • 企业实缴出资额怎么查
  • 产品种类很多月末怎么结转生产成本
  • 现金折扣通过财务费用核算
  • 购房房产税如何支付
  • 不动产融资租赁服务属于租赁服务吗
  • 其他应收款社保个人部分分录
  • 房地产企业已预缴增值税如何抵扣
  • 个人业务费是什么
  • 客户汇公司账户怎么汇
  • 如何安装os x
  • 电脑经常重新启动是什么原因
  • 开具红字发票信息表对方未接受到怎么办
  • 关于其他应收款账户的说法
  • 收到发票怎么入库
  • 暂估入库的处理方式有哪三种
  • php文字转语音源码
  • 计算完工产品成本
  • yii框架运行原理
  • ros算法
  • vue后端框架推荐
  • 销售退换货的账务处理
  • 应付账款转入营业外收入会计分录
  • 单位食堂厨房设计方案
  • day11-Servlet01
  • 收到退税收入
  • 织梦怎么用模板建站
  • 期间费用指哪些费用
  • 土地增值税采用
  • 小卖部铺货首次送货流程
  • 印花税会计处理办法
  • 权益法转其他权益工具
  • 个体工商户生产经营所得税优惠政策
  • 财务费用?
  • 医保账户收入金额是怎么算的
  • 筹建期费用需要结转吗
  • 公司的进账能打到私人卡上
  • 待抵扣进项税额是什么情况下用的
  • 人力成本工资总额指应发工资
  • 个人社保缴纳会不会自动扣款
  • 待抵扣税额怎么做分录
  • 购买食品应注意哪些问题?
  • 企业购入树木花草如何入账
  • sedsvc.exe是什么
  • redhat 7.0
  • centos安装ufw
  • cmos是一种什么芯片
  • linux系统中安装软件
  • win8系统电脑没声音怎么办
  • win10预览版和正式版
  • win7共享文件夹设置访问权限
  • perl中qw
  • shell脚本获取进程pid
  • 批处理技术有哪些
  • jquery实现输入框自限制
  • linux shell脚本命令
  • python入门100例
  • 莱鸟人集团
  • js面向对象的三大特性
  • 如何通过发票号下载电子发票
  • 如何在同一台电脑上投屏
  • 社保卡手机缴费怎么交不了
  • 2021沈阳车船税
  • 税局签三方
  • 护士的专业素质要求
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设