位置: 编程技术 - 正文

Jquery promise实现一张一张加载图片(jquery prototype)

编辑:rootadmin

推荐整理分享Jquery promise实现一张一张加载图片(jquery prototype),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:jquery中的prop,jquery prompt,jquery prop,jqueryprev,jquery prompt,jquery prompt,jquery prop,jquery propertychange,内容如对您有帮助,希望把文章链接给更多的朋友!

Promise是CommonJS的规范之一,拥有resolve、reject、done、fail、then等方法,能够帮助我们控制代码的流程,避免函数的多层嵌套。如今异步在web开发中越来越重要,对于开发人员来说,这种非线性执行的编程会让开发者觉得难以掌控,而Promise可以让我们更好地掌控代码的执行流程,jQuery等流行的js库都已经实现了这个对象,年底即将发布的ES6也将原生实现Promise。

在javascript设计模式实践之代理模式--图片预加载中用代理模式实现了图片预加载功能。

现在就更进一步,完成一个能够一张一张的连续图片加载的功能。

功能:

1.一张一张加载图片。

2.加载错误,超时后显示加载失败图片。

对于功能的要求,肯定会存在对加载状态事件的处理以及完成时回调函数的处理,这样不仅会造成代码上的混乱,甚至破坏各种原则,就不再用普通的方法去写了。针对这种状态通知的特点,比较合适采用promise架构进行处理,promise本质上就是订阅发布设计模式的一种,当前这个功能就用jquery自带的promise进行开发。

1.完成一个加载图片的代理创建函数,可以生成一个带有加载超时、失败、成功、取消监控能力的代理。

其中,通过以下的方式创建了一个Deferred对象

Deferred对象通过resolve方法触发完成事件,使用done方法响应完成事件。

加载成功时的完成事件。

Jquery promise实现一张一张加载图片(jquery prototype)

以及加载完成时的响应处理,就是把图片设到元素上,下面的代码是上面链式写法的拆解。

Defferred对象通过reject方法触发拒绝事件,使用fail方法响应拒绝事件,表示加载失败。

在加载超时,终止,异常时的拒绝事件。

以及加载失败时的响应处理,设置失败图片。

在代理函数的最后,返回deferred的promise对象,用于给调用的地方监控加载的完成和失败态,以便于下一张图片的加载。

return dfd.promise();

2.一张一张的连续加载

做一个loadOneByOne的加载递归函数。

内部先创建一个加载代理,在代理加载完图片,不管是成功还是失败后,递归调用loadOneByOne函数加载下一张图片。

关键就在于代理函数返回的promise对象,使用.always方法可在加载完成后(成功或失败)进行loadOneByOne递归调用加载下一张。

至此完成。

采用了promise模式后,callback函数不见了,维护状态的函数和内部变量也不见了,代码更清晰简单,使得代理函数和本地函数之间的一致性得到保护。

完整代码:

以jQuery中$.Deferred对象为例讲解promise对象是如何处理异步问题 Promises是一种令代码异步行为更加优雅的抽象,它很有可能是JavaScript的下一个编程范式,一个Promise即表示任务结果,无论该任务是否完成。在一些现代

jquery动画效果学习笔记(8种效果) 1、元素的显示和隐藏display:none;隐藏display:block;显示简单显示和隐藏方法a)show()显示b)hide()隐藏c)toggle()开关,显示则隐藏,隐藏则显示scripttype="text/javascrip

jquery实现九宫格大转盘抽奖 下面我们来分享一个九宫格抽奖特效特效说明:一款jQuery九宫格大转盘抽奖代码网页特效,点击抽奖按钮开始随机抽奖选择奖品,可设置起点位置、奖

标签: jquery prototype

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

上一篇:jquery转盘抽奖功能实现(h5抽奖转盘)

下一篇:以jQuery中$.Deferred对象为例讲解promise对象是如何处理异步问题(jquery的deferred)

  • 耕地占用税是什么税种
  • 简易计税方法和免税该怎么选择
  • 普票加专票超过30万全交税吗2020
  • 怎样填写增值税普通发票
  • 广告公司个人所得税几个点
  • 预收和应收可以冲销吗
  • 个税手续费返还计入哪个科目
  • 未取得发票的费用
  • 境内企业向境外放款额度最长放款期限为两年
  • 房地产公司产品无偿提供他人使用 税
  • 知道增值税如何计算开票金额
  • 事业单位取暖费标准
  • 交易性金融资产的入账价值
  • 暂估入库已结转怎么处理
  • 增值税起征点有啥用
  • 小规模建筑企业预缴税款
  • 公司提供职工午餐违法吗
  • 一张报关单上最多不能超过
  • 土地一次开发和二次开发
  • 纳税人跨县(市、区)是指
  • 金税盘开票出现离线发票金额超出限制怎么设置?
  • 季度申报财务报表如何更改
  • 子公司评估增值 出售股权
  • 个人独资企业所得税缴纳标准
  • 内外账合并步骤
  • 职工领取企业年金税收优惠
  • 防伪税控设备丢失需要处罚吗
  • 如何修改系统时间为12/24小时制
  • 搜索特定
  • 苹果macbook 系统
  • php大量数据处理
  • ubuntu18更换为阿里源
  • linux系统的介绍
  • php最好的编程语言
  • PHP:getimagesizefromstring()的用法_GD库图像处理函数
  • 若依框架和jeesite
  • vue 移动端
  • 收到无法支付的押金收入
  • 生产企业出口退税申报流程操作
  • yii2整合百度编辑器umeditor及umeditor图片上传问题的解决办法
  • 劳务报酬已扣税是否需报个税
  • nvidia-smi failed to initialize
  • php swoole框架
  • 结存材料实际成本分录
  • php的二维数组
  • 汇算清缴管理费用明细有哪些
  • dedecms进入数据库
  • php 时间
  • 调转会计证需要什么资料
  • 预付账款可以抵扣增值税么
  • 申报个税的流程怎么操作
  • 个人所得税年度累计扣税规则
  • 行政单位应缴预算款原则上按月缴清
  • 什么叫应纳税额六年级下册
  • 集团公司对子公司总经理的绩效考核
  • 新担保法2021和担保期限
  • 工程预交税金是什么意思
  • 金税盘技术维护费可以抵扣吗
  • 本年利润有余额么
  • 建账前应该考虑哪些问题
  • mysql --help
  • mysql5.5怎么用
  • Win2008 R2 mysql 5.5 zip格式mysql 安装与配置
  • mysql查看使用情况
  • winxp纯净版系统
  • 如何设置win10系统输入法
  • win10查看电脑配置显卡
  • win10鼠标移动速度怎么设置
  • 批处理注册reg文件
  • node.js中使用文件流进行文件复制,首先需要创建一个
  • node断点调试
  • js删除li
  • shell bash sh
  • 怎么利用python爬虫爬数据
  • 购买的环保设备未使用检察建议
  • 如何打印个人所得税证明
  • 法院执行的房子可以卖吗
  • 北京税务局待遇有住宿吗
  • 纳税人逾期未申报的原因有哪些
  • 佛山电动摩托车能上牌吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设