位置: 编程技术 - 正文

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

  • 企业所得税会计科目
  • 离岸价的含义
  • 医疗保险单位和个人交的区别
  • 信用代码证过期银行能转账吗
  • 个体工商户免征税额度是多少
  • 深圳增值税发票选择确认平台使用
  • 建筑业工人工资保障
  • 企业之间无偿借款
  • 材料成本差异结转借贷方向
  • 公司清算后资产负债表与利润表
  • 建账录入期初数据需要看哪个表
  • 应付职工薪酬月末结转到哪里
  • 房租发票9%还是5%
  • 移动电子发票怎么发送到邮箱
  • 小规模纳税人实行简易征收办法
  • 一般纳税人企业所得税计算公式
  • 本月应该确认收入,但是一般下月才开票该怎么处理?
  • 文化建设费的征收标准
  • 高新产业扶持补贴怎样申请
  • 个人所得税款项性质
  • 苹果14如何强制关机重启
  • 出口报关单有什么用
  • 生产企业出口退税全部流程
  • 苹果客服人工24小时
  • window10系统有几种
  • linux取消静态ip
  • php string函数
  • 展会费用计入什么科目
  • scards32.exe - scards32是什么进程 有什么用
  • php ftell
  • 研发费用加计扣除75%还是100%
  • 拍卖有抵押的车子怎么处理
  • 企业缴税科目
  • 一次摊销法计算公式
  • 细说php
  • 资产负债表是不是根据记账凭证生成的
  • transformer中的token
  • 交易性金融资产的入账价值
  • 用友t6模块
  • 合并报表的会计主体
  • 怎么样去掉
  • 对公付款对方不发货不退钱怎么处理
  • mysql出现的问题
  • sqlserver存储过程教程
  • 公司租赁房屋房产税
  • 投资收益算在营业利润里面吗
  • 安装固定资产所消耗的材料费和人工费属于什么会计科目
  • 进项税已入账未认证申报表怎么填
  • 企业年金个税怎么计算
  • 公司有美金账户如何做账
  • 运费账务怎么处理
  • 出售无形资产损失
  • 没有开票的收入要交增值税吗
  • 工业企业中制造费用包括哪些内容
  • mysql中注释
  • win7 组织
  • win2003安全模式怎么进
  • linux pptp客户端
  • freebsd版本选择
  • win10怎么关闭定时断网功能
  • Linux配置防火墙端口
  • auepuf.exe是什么进程
  • 装win7ahci
  • win7开始图标怎么变大点
  • 怎么关闭获取手机信息
  • ubuntu系统安装程序
  • centos7图形安装
  • 如何判断肾虚阴虚阳虚
  • hosts文件win10
  • android搭建环境
  • jquery实现select选择框内容左右移动代码分享
  • perl脚本教程视频
  • perl随机数
  • 批处理在windows中的典型应用
  • unitytest
  • javascript简单代码
  • android动画实现方式
  • 为什么医保名字不一样
  • 湖北国税网上办税大厅官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设