位置: 编程技术 - 正文

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进行即时验证实例详解

  • 收到所得税汇算退税计入补贴收入
  • 投资性房地产税务上可以计提折旧吗
  • 如何确认产品销售收入
  • 保险公司报销修手机
  • 个税申报表中的基本养老保险怎么填
  • 企业购置房产进项被折旧怎么处理
  • 预收款方式销售货物
  • 税控盘技术维护费申报时候怎么填报
  • 小规模纳税人每季度报税清盘
  • 小规模纳税人季报还是月报?
  • 中标服务费可以抵扣进项税吗
  • 企业所得税虚报成本多少属于犯罪
  • 出口预收货款发生的时间和报表上的时间不一样怎么办
  • 慈善机构捐赠
  • 银行余额调节表模板
  • 物业费增值税是什么税
  • 期末留抵税额转出怎么报税
  • 企业所得税中准予扣除的损失
  • 企业购车可以一次性扣除吗
  • 公司注销留抵税金能退税吗
  • 城镇退役士兵安置条例
  • 新会计准则下职工薪酬的变化及影响摘要
  • 股东撤资退出
  • win8系统如何设置u盘启动
  • win11最低硬件要求几代
  • 中途建账科目余额表怎么建
  • 代扣代缴的增值税可以作为进项税抵扣吗
  • php创建二维数组
  • php 递归函数
  • 计入固定资产成本的费用
  • PHP:stream_get_transports()的用法_Stream函数
  • 000.exe病毒
  • 移动有聊天室平台吗
  • ctblocker
  • 怎么检查当年的核酸结果
  • 收到业绩补偿会扣税吗
  • 结转损益类收入科目的余额会计分录
  • php实现留言板功能
  • mysql刷新数据
  • 公司注册完成以后需要做哪些事情
  • 多收钱少开票
  • 综合所得个税计算例题
  • 资产总额不超过5000万是指全年平均收入吗
  • 未经审计情况说明怎么写
  • mysql更新视图的方式
  • 盈余公积提取后需要结转吗
  • 无票收入后又开票怎么办
  • 职工薪酬包括哪几类
  • 房地产企业土地增值税清算
  • 利润减负债
  • 国有资产无偿划转需要缴税吗
  • 公司购车购置税可以抵扣吗
  • 企业清算是怎么做账的
  • 简易办法征收增值税是什么意思
  • 生产车间为生产产品
  • 理财到期的会计怎么做账
  • 固定资产折旧递延收益
  • 垫付的资金
  • 持有至到期投资在资产负债表怎么填
  • 公交卡充值发票怎么开
  • 跨年退货怎么处理账务
  • 营业费用和营业支出
  • mac开机后蓝屏没反应
  • linux vps 教程
  • linux认证失败的原因
  • win10一直显示正在配置更新
  • linux安装软件怎么安装
  • linux制作
  • 批处理修改文件修改日期
  • unity多人语音
  • vb中chr$(13)是什么意思
  • android基于什么操作系统
  • 你所不知道的童话动画版免费观看第二季
  • jquery监听span内容的变化
  • 用python写脚本
  • js 类的继承
  • javascript面向对象编程指南第三版
  • 同城通办办税大厅
  • 普惠性和非普惠的区别
  • 新疆皮山县概况
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设