位置: 编程技术 - 正文

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

  • 小微企业企业所得税计算公式
  • 简易计税方法是什么意思
  • 印花税计提缴纳的会计分录
  • 基本户可以直接转账给个人吗
  • 员工工资计入管理费用吗
  • 建账的主要流程
  • 自然人合伙企业怎么交税
  • 哪些车辆可退还车款
  • 共同控制合营企业
  • 存货计提减值准备是什么原则
  • 预收款开票的税务处理
  • 代扣代缴增值税是什么意思
  • 增值税专用发票有效期是多长时间
  • 国家认定的高新技术企业是什么意思
  • 增值税专用发票开票必填项
  • 技术服务合同增值税免税吗
  • 绿植租赁公司都适合什么名字
  • 出口专用发票可抵扣吗
  • 慈善基金会的含义
  • 作业成本法的成本对象包括哪几个层次
  • 中药饮片加成率超的原因
  • 轩辕剑3字体
  • win11怎么取消开机启动项
  • 商业承兑汇票分为哪两种
  • php快递查询系统
  • php实现的一致性是什么
  • php中提交表单数据
  • 附加税异地预缴如何申报
  • PHP:session_decode()的用法_Session函数
  • PHP:pg_fetch_row()的用法_PostgreSQL函数
  • php实战
  • 未取得合法有效凭证可以税前扣除
  • 贷款和应收款项应采用实际利率法
  • 一般纳税人辅导期最新规定
  • 买二手房避税
  • 最早的笔记本是512m内存
  • 有限责任公司股东对公司债务承担
  • [error] Error: Fail to open IDE 问题解决
  • 小规模纳税人季报需要报什么
  • idea配置meaven
  • parted命令详解
  • php 方括号
  • 服装、眼镜、鞋、西药的发票怎么样做账比较好
  • 三类职业指的是什么
  • 推广服务费可以抵扣吗
  • mysql线程数配置
  • python转换数字
  • 公司安排异地培训
  • 企业变更股东需要什么手续
  • 食堂账目怎么做
  • 小规模纳税人税金账务处理
  • 分公司是独立的诉讼主体吗
  • Windows下Postgresql数据库的下载与配置方法
  • 跨年费用账务处理
  • 公司给员工付个税怎么交
  • 其他综合收益会影响未分配利润吗
  • 减免的企业所得税是否需要征税 税屋
  • 包装物租金如何界定
  • 付国外客户佣金怎么代扣代缴增值税
  • 专票 跨年
  • 电影院分成比例
  • 绿化植物税率
  • 新公司季初资产总额填什么
  • 利润表每股收益增加说明什么
  • sql server减法
  • vnc server apk
  • win8的系统
  • Win10预览版怎么变回正式版
  • 怎么优化win10系统
  • win7旗舰版磁盘清理
  • 怎么用linux运行c程序
  • unity3d官方案例
  • jquery获取当前对象
  • python正则\b
  • Javascript在网页设计中的作用有哪些
  • 山东税务局电子税务局申报
  • 湖南电子税务局官网登录入口首页
  • 台州土地成交
  • 我国税收征收机关包括
  • 增值税号和增值税账号的区别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设