位置: 编程技术 - 正文

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

  • 2019年的个税现在还可以退吗
  • 企业所得税当年销售收入
  • 增值税小规模纳税人认定标准
  • 如何判断固定资产资本化还是费用化
  • 计入损益的税
  • 发票报送失败怎么弄
  • 股东出让个人股权流程
  • 银行汇票应计入什么科目
  • 国外客户给你寄来礼物怎么感谢
  • 工资中的考核罚款会计怎么处理?
  • 计提与不计提短贷的区别
  • 发票勾选没有确认怎么办
  • 单位给员工上的商业险是什么
  • 小规模季度销售超过30万怎么纳税
  • 增值税发票开户行填简称是被允许的吗?
  • 分公司亏损还会分摊所得税吗
  • 企业净资产增长率上升说明什么
  • 预收一年租金会计分录
  • 不锈钢材料开票
  • 账面销项税额与申报表不一致怎么处理
  • 装修费可以作为开办费吗
  • linux怎么添加命令
  • 企业取得的利息收入 用什么科目
  • 支付境外特许权许可使用费资料
  • 在linux中使用什么命令可以动态查看文件内容
  • win7系统管理员密码忘了怎么办
  • php判断https
  • 公司多缴税款了怎么办?可以退吗?
  • 用银行存款支付本季度短期借款利息
  • 政府闲置土地
  • 斯诺多尼亚山
  • 会计核算中 制度有哪些
  • php功能模块
  • 税务申报说明怎么写范文
  • CUDA版本选择
  • yolov5中使用的限制目标宽高的方法防止梯度爆炸
  • linux symbolic link
  • 存货盘盈的账务处理入什么费用
  • 物业公司的会计科目有哪些
  • 公司目前销售使用的物品
  • 帝国cms使用手册
  • 一般纳税人第一次申请发票
  • mysql版本5.5.x升级到5.6.x步骤分享
  • 劳务公司社保手续办理
  • sql 语法树
  • 只收加工费
  • 地方水利建设基金减免政策2023
  • 应收款和实收款区别
  • 盈余公积提取多了
  • 事业单位结余是什么意思
  • 应交增值税结转凭证
  • 出口退税账务处理难吗
  • 发出存货的计价应当采用
  • 管理费用的核算要求
  • 房地产企业预缴增值税
  • 限售股锁定期延长
  • 应付股利计提了长期不支付
  • 小规模纳税人发票可以抵扣吗
  • 其他业务收入冲减应付账款
  • 企业购入树木花草如何入账
  • 零申报必须会计吗?自己可以操作吗
  • 应收账款的账户余额
  • 系统的虚拟内存可以清理吗
  • win10蓝屏后黑屏
  • win8资源管理器在哪
  • win8小键盘怎么打开
  • win10更新需要重启怎么办
  • win7无法打开windows功能
  • win7系统找不到蓝牙设备
  • jquery插件是干什么的
  • 环境篇心中有光的作文
  • cocos2d android
  • shell 数组变量
  • js nextSibling属性和previousSibling属性概述及使用注意
  • Linux命令行和shell脚本编程大全
  • android Lollipop(5.0)--touch feedback(触摸反馈)
  • android多点触控
  • 小规模纳税人开专票可以抵扣吗
  • 出口退税是哪个环节交的
  • 赞美税务局的话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设