饥人谷技术博客

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

2016-05-04  本文已影响0人  种谔

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

  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(滚动条)的配色

.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解析源码

上一篇下一篇

猜你喜欢

热点阅读