关于Promise、Deferred和自定义滚动条样式的入门

Promise

  • 在JavaScript的世界中,所有代码都是单线程执行的。由于这个“缺陷”,导致JavaScript的所有网络操作,浏览器事件,都必须是异步执行。但是有时候我们的一些代码需要在这些异步执行完之后再执行,完成异步之下的同步执行,于是就诞生了Promise对象。

  • 简单应用

// 0.5秒后返回input*input的计算结果:
function multiply(input) {
    return new Promise(function (resolve, reject) {
        log('calculating ' + input + ' x ' + input + '...');
        setTimeout(resolve, 500, input * input);
    });
}
// 0.5秒后返回input+input的计算结果:
function add(input) {
    return new Promise(function (resolve, reject) {//注意这边的返回值又是一个Promise对象,可以链式调用
        log('calculating ' + input + ' + ' + input + '...');
        setTimeout(resolve, 500, input + input);
    });
}
var p = new Promise(function (resolve, reject) {//这边的resolve和rejec是两个标记,决定执行then还是catch中的参数。
    log('start new Promise...');
    resolve(123);
});
p.then(multiply)//把multiply函数替代resolve执行了,参数是resolve上的参数。
 .then(add)
 .then(multiply)
 .then(add)
 .then(function (result) {
    log('Got value: ' + result);
});

Deferred

  • deferred对象就是jQuery的回调函数解决方案,也是Promise对象的加强版本,不过Promise是通过传入的 函数中两个参数resolve和reject来决定,执行的是then中的函数还是catch中的函数。

  • 而defered对象则是根据自己属性的状态,来判断执行done方法、fail方法、progress方法中的哪个方法,defered对象和Promise对象使用类似,只是defered更抽象,本质只是一个标识执行状态的状态机。

  • 简单应用

  var wait = function(){
    var dtd = $.Deferred(); //在函数内部,新建一个Deferred对象
    var tasks = function(){
      alert("执行完毕!");
      dtd.resolve(); // 改变Deferred对象的执行状态
    };    setTimeout(tasks,5000);
    return dtd.promise(); // 返回promise对象
  };
  $.when(wait())
  .done(function(){ alert("哈哈,成功了!"); })
  .fail(function(){ alert("出错啦!"); });
  • 等待多个异步调用函数执行完成之后再执行
  $.when($.ajax("test1.html"), $.ajax("test2.html"))
  .done(function(){ alert("哈哈,成功了!"); })
  .fail(function(){ alert("出错啦!"); });

用CSS调整scrollbar(滚动条)的配色

  • 如果仅要求IE浏览器,可以通过调整CSS的方式,来给滚动条换色。代码如下
.uicss-cn
{
height:580px;overflow-y: scroll;
scrollbar-face-color:#EAEAEA;
scrollbar-shadow-color:#EAEAEA;
scrollbar-highlight-color:#EAEAEA;
scrollbar-3dlight-color:#EAEAEA;
scrollbar-darkshadow-color:#697074;
scrollbar-track-color:#F7F7F7;
scrollbar-arrow-color:#666666;
}
  • 各属性说明如图
IE下CSS滚动条属性说明图.png

注意:到目前为止尚未发现统一的解决方案,FF、IE、chrome浏览器实现的滚动条的API各有不同,详情见参考文章。

参考文章:
滚动条自定义样式
jQuery的deferred对象详解
Promise
Javascript 中的神器——Promise
Promise解析源码

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 本文适用的读者 本文写给有一定Promise使用经验的人,如果你还没有使用过Promise,这篇文章可能不适合你,...
    HZ充电大喵阅读 12,067评论 6 19
  • Promise 的含义 一句话概括一下promise的作用:可以将异步操作以同步操作的流程表达出来,避免了层层嵌套...
    雪萌萌萌阅读 10,881评论 0 7
  • //本文内容起初摘抄于 阮一峰 作者的译文,用于记录和学习,建议观者移步于原文 概念: 所谓的Promise,...
    曾经过往阅读 5,017评论 0 7
  • 今秋是金秋,明日便是冬. "自古逢秋悲寂寥,我言秋日胜春朝". 秋天,是岁月特意散落人间的一粒种子. 在静好的时光...
    爱妃给朕笑一个阅读 3,652评论 0 1
  • 原文地址:李启雷的博客 以太坊是什么? 以太坊(ethererum)是一个开放的区块链平台,任何人都可以基于以太坊...
    李启雷阅读 12,107评论 3 2

友情链接更多精彩内容